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TECHNICAL FIELD OF THE INVENTION 

[0001] The present invention pertains in general to electrophotographic printers 
and, more particularly, to a plurality of print engines arranged in parallel to process 
print jobs in a parallel manner. 

5 CROSS REFERENCE TO RELATED APPLICATIONS 

[0002] This Application is a Continuation-in-Part of Serial No. 09/044,539, filed 
March 19, 1998. titled "METHOD AND APPARATUS FOR DETERMINING 
TONER LEVEL IN ELECTROPHOTOGRAPHIC PRINT ENGINES," (Arty. Dkt. 
No. TRSY-23,859) which is a Continuation-in-Part of Serial No. 08/698,999, filed 
1 0 December 5, 1 997, titled "MULTIPLE PRINT ENGINE WITH VIRTUAL JOB 

ROUTING" (Atty.Dkt.No. TRYS-23,684), which is a Continuation of Serial No. 
08/698,999, filed August 16, 1996, titled "MULTIPLE PRINT ENGINE WITH 

2 



VIRTUAL JOB ROUTING" (Atty.Dkt.No. TRSY-23,684), abandoned, which is a 
Continuation-in-Part of Serial No. 08/51 1,641, filed March 2, 1998, titled 
"VIRTUAL SINGLE PRINTER ENGINE WITH SOFTWARE RIP" (Atty.Dkt.No. 
TRSY-23,617), which is a Continuation of Serial No. 08/51 1,641, filed August 7, 
5 1 995, titled "VIRTUAL SINGLE PRINTER ENGINE WITH SOFTWARE RIP" 

(Atty.Dkt.No. TRSY-23,617), abandoned. 
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BACKGROUND OF THE INVENTION 



[0003] Electrophotographic print engines have been utilized with both printers and 
copiers. In a printer, the print engine is typically interfaced with a computer to 
select and organize fonts or bit map the images. In a copier application, the print 

5 engine is interfaced with an input device that scans the image onto the 

photoconductor drum of the print engine. However, a CCD device could also be 
utilized in this application in the form of a CCD scanner. In either of the 
applications, a conventional print engine for a monochrome process would typically 
feed a single sheet of paper and pass it by the photoconductor drum for an image 

10 transfer process and then pass it to a fuser. Thereafter, the completed sheet will be 
output. Multiple copy print jobs will sequentially feed the paper in a serial manner. 
The speed of the printer is a function of the speed at which the image can be created, 
the speed at which the image can be transferred to the paper and the speed of the 
fuser. As increased output is required, the speed of each of these elements must be 

15 increased. 

[0004] In a monochrome process, only one transfer operation is required. 
However, in a multipass color process, multiple images must be superimposed on 
one another on the sheet of paper in a direct transfer system, thus requiring multiple 
passes of the paper or image carrier through the print engine. In a double transfer 

20 system, the image is disposed on an intermediate dram and then the composite 

image transferred to the paper or image carrier. In a multiple print job on a direct 
transfer system, this requires each sheet of paper to be printed in a serial manner by 
passing it through the print engine. For either the monochrome process or the color 
process, a conventional serial feed print engine has the output thereof defined by the 

25 speed of the input device and the speed of the print engine itself. 

[0005] One technique that has been utilized to increase throughput is a tandem 
print engine. In a tandem print engine, multiple colors can be disposed on the sheet 
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of paper or the image carrier at different stations that are disposed in serial 
configuration. In this manner, the speed is the same for one, two, three or four color 
printing. 



5 [0006] When dealing with multiple print engines, there can be a problem that 

exists with respect to insuring that there is adequate "color balance". In general, all 
color devices have a native range of colors in which they operate. This is called the 
color gamut of that device. Any color that falls within this gamut can be 
reproduced. Any color that falls outside cannot. This gamut is defined by the 

10 hardware of the device and its addressability. A monitor uses a phosphorus of some 
given type and is addressed in 8 bits per channel of RGB. This native gamut or 
range of colors changes for every different device. If it is desirable to reproduce a 
color on some devices, two things have to occur. First, those devices would have to 
be able to make that color, meaning, have that given color inside their gamuts. 

15 Second, the color would have to be correctly described, or defined as it moves from 
one device to another. RGB, CMYK, Lab, LCH, are all methods that devices can 
utilize to describe colors. They do not always have a direct translation between 
them, however. A method is needed to correctly translate between these methods. 
The analogy is as if one person would speak German and another spoke french, 

20 wherein an intermediate or interpreter would be required in order to provide 

communication. One method for solving this problem is to use a device independent 
(or color independent) space. A number of years ago, the CIE created a device 
independent space (XYZ) that defines color based on the light source they are 
viewed under, and the color response of the eye. A color independent space is a 

25 mathematical way to map device gamuts to see where they intersect. Where they 

intersect represents the colors they share. It is also the best platform for determining 
which color to use if gamuts do not intersect. Also, in this master color space, all 
colors are described or defined using the same terms, independent of any device. In 
this space, all colors are brought to a common ground. Once a color is defined in 

30 XYZ space, it can be sent and accurately reproduced on any device whose gamut in 
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XYZ space includes that color. The reproduction of any color is accomplished by 
correlating the device native gamut to the color independent space. 

[0007] During a conventional print operation, toner is used up at a rate that is 
actually defined by the amount of information that is disposed on the given page 

5 multiplied by the number of pages. Typically, systems incorporate some type of 
page counter that, when it exceeds a predetermined number of pages, indicates that 
the toner is low. This, of course, is reset when a new toner cartridge is disposed in 
the printer. However, this toner decision is made strictly based upon the number of 
pages and not the amount of toner actually depleted from the toner cartridge. This is 

10 due to the fact that some pages have a very light toner usage compared to others. 

For example, an image having a large percentage of black area associated therewith 
will utilize a large amount of toner, whereas a page having very light gray regions 
will utilize a small amount of toner. As such, the determination of a low toner level 
in a cartridge is extremely inaccurate. 
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SUMMARY OF THE INVENTION 

[0008] The present invention disclosed and claimed herein comprises a method for 
determining the actual toner density level in a toner cartridge for a printer. Each 
page in a multi-page document is rasterized and then the rasterized image evaluated 
5 to determine what percentage of the pixels are turned on and to what level they are 
turned on. An average value is then generated to determine the percent toner 
relative to a full page that is to be utilized by the printer. When the page is printed, 
a toner density value register is decremented such that the toner density value will 
represent the toner that remains in the cartridge. 

10 [0009] In another aspect of the present invention, each page of the multi-page 

document is rasterized and evaluated prior to printing. The toner usage for the entire 
document is then decremented from the toner density value and this value compared 
to a minimum value. If it falls below the minimum value, then printing is inhibited. 
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BRIEF DESCRIPTION OF THE DRAWINGS 



[0010] For a more complete understanding of the present invention and the 
advantages thereof, reference is now made to the following description taken in 
conjunction with the accompanying Drawings in which: 

[0011] FIGURE 1 illustrates an overall block diagram of the virtual printing 
5 system; 

[0012] FIGURE 2 illustrates a more detailed block diagram of the virtual printing 
system; 

[0013] FIGURES 3a, 3b and 3c illustrate three general processing configurations; 
[0014] FIGURE 4 illustrates a cutaway side view of a three module multiple print 
10 engine operated in accordance with the virtual printing system; 

[0015] FIGURE 5 illustrates a flowchart illustrating the parsing operation; 
[0016] FIGURE 6 illustrates a flowchart for the duplex operation for a face up 
output; 

[0017] FIGURE 7 illustrates a flowchart for the duplex operation for a face down 
15 output. 

[0018] FIGURE 8 illustrates a diagrammatic view of the stacking configuration to 
define a collation and gathering operation; 

[0019] FIGURE 9 illustrates a block diagram of the overall job parsing operation; 
[0020] FIGURE 10 illustrates the parsing operation for each printer at given jobs; 
20 [0021] FIGURE 1 1 illustrates process flow for the job parsing operation; 
[0022] FIGURE 12 illustrates a flowchart for the parsing operation; 
[0023] FIGURE 13 illustrates a flowchart for the overall virtual job routing 
operation; 

[0024] FIGURE 14 illustrates an overall block diagram of the system; 
25 [0025] FIGURE 1 5 illustrates a block diagram of the lower level architecture 
between the virtual printer and the physical print engine; 
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[0026] FIGURES 16, 17 and 18 illustrate flowcharts for the engine allocator; 
[0027] FIGURE 19 illustrates a flowchart for the resource allocator; 
[0028] FIGURE 20 illustrates a prior art PCI bus structure; 
[0029] FIGURE 21 illustrates a block diagram of the host adapter/print adapter of 
5 the present system; 

[0030] FIGURE 22 illustrates a block diagram of the host adapter; 
[0031] FIGURE 23 illustrates a block diagram of the print adapter; 
[0032] FIGURE 23a illustrates a detail of the translator; 
[0033] FIGURE 24 illustrates a timing diagram for the unload operation of the 
10 FIFO in the print adapter; 

[0034] FIGURE 25 illustrates a block diagram of the manner in which the device 
profiles are handled in a prior art system; 

[0035] FIGURE 26 illustrates a block diagram of a conventional system for 
balancing color space; 
15 [0036] FIGURE 27 illustrates the color balancing operation of the present 

invention; 

[0037] FIGURE 28 illustrates a flowchart depicting the calibration method; 
[0038] FIGURE 29 illustrates a test pattern for the fine tune operation for bi-level 
and quad-level; 

20 [0039] FIGURE 30 illustrates a flowchart for the fine tune operation; 

[0040] FIGURE 3 1 illustrates a block diagram of the REP; 
[0041] FIGURE 32 illustrates a flowchart for the output plug-in portion of the 
RIP; 

[0042] FIGURE 33 illustrates a flowchart for the toner calculation operation; 
25 [0043] FIGURE 34 illustrates a flowchart for the power-on sequence operation; 

[0044] FIGURE 35 illustrates a flowchart for the merge operation; 
[0045] FIGURE 36 illustrates a flowchart for the stack control operation; 
[0046] FIGURES 37 and 38 illustrate flowcharts for the page synchronization 
operation; 
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[0047] FIGURE 39 illustrates a block diagram of an embodiment of the present 
invention utilizing an automatic finishing step; and 

[0048] FIGURE 40 illustrates a flowchart for the embodiment of FIGURE 39. 
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DETAILED DESCRIPTION OF THE INVENTION 



[0049] Referring now to FIGURE 1 , there is illustrated a block diagram of the 
overall operation of the virtual printing system. A plurality of workstations 10 are 
provided, which workstations 10 comprise general personal computers or other 
5 terminals that allow a user to create print jobs. Each of the workstations is 

networked through a network interface 12, which is a conventional type of general 
network interface such as an Ethernet® network interface. This allows each 
workstation 10 to send its print job to a central processor 14, which processor is 
operable to process the print jobs in accordance with the system of the present 

10 invention and distribute these print jobs to multiple print engines 16. As will be 
described hereinbelow, the processor 14 is operable to disassemble the print job, 
parse the print job into different pages and distribute the parsed pages in a 
predetermined manner in accordance with the present invention. It should be 
understood that a print job, although initiated as a series of pages, is sent as a single 

15 job to a printer. Typically, printers receive the print job in a conventional manner, 
which is a string of digits and the printers determine whether the codes are for an 
end of page command, etc. However, most print operations within a given 
workstation 10 are designed such that the print job is to be sent to a single printer 
and, therefore, the codes are all "bundled" in a common string or job. As will be 

20 described hereinbelow, in order for the pages to be parsed, it is important to first 

determine what the beginning and the end of a print job is, then determine what 
printer to send that distinct and separate page to, in accordance with the system of 
the present invention. 

[0050] Referring now to FIGURE 2, there is illustrated a more detailed block 
25 diagram of the operation of the processor and the parsing operation for distributing 

the parsed pages to the various print engines 16. The job is received in a serial 
manner, and is "spooled" in a print spooler 20. This is then passed to a software RIP 
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engine 22 which is operable to essentially decode the print string that is received 
from the print spooler 20. This effectively divides each print job into pages. These 
pages are then stored in page buffers 24. Each page in the page buffer essentially 
constitutes a single print job, such that any print job received from the workstations 
5 10 will then be parsed into a multiple print job file. For example, if a thirty page 
document were to be sent, this would be sent as a single print job, which would be 
encoded as such. The software RIP engine 22 is then operable to divide this into 
thirty separate print jobs. 

[0051] Once the pages are stored in the page buffer 24, then the pages are sent to 
10 an image task manager 26 to determine how to organize the pages. This operates in 
conjunction with an engine manager 28 to determine which of the print engines 16 
the job is to be passed to. In order to effectively increase the throughput from the 
engine manager 28, there are provided interface circuits 32 which are referred to as 
Peripheral Connect Interface (PCI) adaptors. Each print engine 16 has a PCI 32 
15 associated therewith. Therefore, the engine manager 28 interfaces with the PCIs 32 
through a parallel bus 36, such that data can be transferred thereto at a fairly high 
data rate, which is the bus transfer data rate of the processor 14. The PCIs 32 
therefore provide an increased rate of transfer to the print engine 16. The print 
engines 16 then place their output into a separate output bin 40 for each of the print 
20 engines 16. 

[0052] As will be described hereinbelow, the image task manager 26 is operable to 
arrange the copies such that they can be placed in the output bins 40 in a 
predetermined order. For example, if there were two print engines, each with a 100 
sheet paper supply and four print jobs of 50 copies each were to be sent to the 
25 printers and the workstation 1 0, the system of the present invention would parse 

these print jobs such that the first two print jobs went to the first print engine and the 
second two print jobs went to the second print engine. If, alternatively, the two print 
engines with the one hundred sheet paper supplies handled two print jobs, one at a 
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150 sheets and one at 50 sheets, then the first print engine would receive the first 
100 sheets from the first print job, the second print engine would receive the first 50 
sheets of the first print job and the second 50 sheets of the second print job. 
However, they would be sent to the printer in such a manner that when the paper 
5 output trays were unloaded and stacked together, the jobs would be arranged in the 
appropriate manner. Therefore, even though there are multiple printers, to the user 
they appear as a virtual single printer. All decision making is made in the 
processor 14. 

[0053] Referring now to FIGURES 3a-3c, there are illustrated the various 

10 configurations illustrating the transfer of data between an input and a print engine. 

In FIGURE 3a, there is illustrated a general diagram of a software RIP processor 42, 
which is operable to generate the data necessary to transfer to a print engine 46. 
However, this is effected over a conventional parallel port 48. In this configuration, 
the software RIP processor 42 is relatively fast, whereas the print engine 46 is 

15 relatively slow. Of the time to print, three percent of that time is occupied by the 
operation of print engine 46, seventy percent is occupied by the software RIP 
processor 42 and twenty-seven percent is occupied by transferring the data from the 
processor 42 to the print engine 46. Therefore, the parallel port 48 becomes a key 
factor in the printing time. In FIGURE 3b, software RIP processor 42 is connected 

20 to the print engine 16 via a PCI 50. In this configuration, ninety-five percent of the 
print time is occupied by the software RIP processor 42, three percent by the print 
engine 16 and five percent by the PCI 50. Therefore, by reducing the transfer time 
from the processor 42 to the print engine 16, an increase in speed has been seen. In 
FIGURE 3 c, there is illustrated a fairly conventional system wherein a processor 52 

25 is provided, which can be a conventional PC for assembling the print job in a 

conventional manner and transferring it via a parallel port 54 to an engine 58, which 
is a conventional print engine having an internal RIP 60 associated with a marking 
engine 62. The processor 52 is relatively fast, and it occupies virtually no time. 
Seventeen percent of the print time is taken passing the data to the RIP 60 through 
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the parallel port 54, whereas eighty percent of the print time is occupied with the 
RIP 60 and only three percent by the marking engine 62. 

[0054] Referring now to FIGURE 4, there is illustrated a cutaway side view of a 
three print engine module parallel printer which includes three print engines 136, 
5 138 and 40, all stacked one on top of the other. Each of the engines 136-140 is a 

multi-pass engine and includes a transfer drum 142 and a photoconductor drum 144. 
The photoconductor drum 144 rotates in a counterclockwise direction and is pressed 
against the transfer drum 142 to form a nip 146 therebetween. The photoconductor 
drum 144 is operable to have the surface thereof charged with a corona 148 and then 

10 an imaging device 1 50 is provided for generating a latent image on the charged 
surface of the photoconductor drum 144. The undeveloped latent image is then 
passed by four developing stations, three color developing stations, 152, 154 and 
156 for the colors yellow, magenta and cyan, and a black and white developing 
station 158. The color developing stations 152, 154 and 156 each have a respective 

15 toner cartridge 160, 162 and 164 associated therewith. The black and white 
developing station 158 has a black and white toner cartridge 166 associated 
therewith. Although not described hereinbelow, each of the developing stations 
152-168 and toner cartridges 160-166 can be removed as individual modules for 
maintenance thereof. 

20 [0055J During the print operation, the photoconductor drum 144 is rotated and the 

surface thereof charged by the corona 148. An undeveloped latent image is then 
formed on the surface of the photoconductor drum 144 and then passed under the 
developing stations 150-158. In a multi-pass operation, the latent image is generated 
and only one color at a time utilized in the developing process for the latent image. 

25 This latent image is then passed through the nip 146 and transferred to an image 

carrier, such as paper, which is disposed on the surface of the transfer drum 142. 
Thereafter, the surface of the drum 144 is passed under a cleaning station 168, which 
is operable to remove any excess toner particles which were not passed over to the 
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transfer drum 142 during the transfer operation and also discharges the surface of the 
drum 144. The system then begins generation of another latent image, either for a 
different color on the same sheet of paper or the first color on a different sheet of 
paper. 

5 

[0056] In the color operation, multiple passes must be made such that the image 
carrier, i.e., paper, remains on the surface of the transfer drum 142 for the multiple 
passes. In the first pass, the first latent image is transferred to the surface of the 
transfer image carrier and then the image carrier maintained on the transfer drum 
10 142. The next latent image of the next color is superimposed on the first latent 

image, it being noted that the registration is important. This registration is provided 
by the mechanical alignment of the various drums, drive mechanisms, etc. 
Thereafter, the third color latent image is disposed on the image carrier followed by 
the fourth color latent image. 

15 [0057] After the last color latent image is disposed on the image carrier in the 

color process, a picker mechanism 172 comes down on the surface of the transfer 
drum 142 in order to lift up the edge of the image carrier or paper. This is then fed 
to a fuser mechanism 174. 

[0058] The image carrier is typically comprised of a predetermined weight paper. 

20 The transfer drum 142 utilizes electrostatic gripping for the purpose of adhering the 
paper to the surface of the transfer drum 142 for multiple passes. This therefore 
utilizes some type of charging mechanism for charging the surface of the drum 142 
at an attachment point 176 where the paper is fed onto the surface of the transfer 
drum 142. The transfer drum 142 is, in the preferred embodiment, manufactured 

25 from a controlled resistivity type material that is disposed over an aluminum support 

layer which is a hollow cylindrical member. A voltage supply is provided that 
provides a uniform application of voltage from the voltage supply to the underside 
of the resilient layer that is disposed over the surface of the aluminum support 
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member. This resilient layer is fabricated from a carbon filled elastomer or material 
such as butadaiene acrylonitorile, which has a thickness of approximately 3 mm. 
Overlying this resilient layer is a controlled resistivity layer which is composed of a 
thin dielectric layer of material at a thickness of between 50 and 100 microns. This 
5 controlled resistivity layer has a non-linear relationship between the discharge (or 

relaxation) point tying and the applied voltage such that, as the voltage increases, the 
discharge time changes as a function thereof. The paper is then disposed over the 
surface of the drum. The construction of this drum is described in U.S. Patent No. 
5,459,560, issued October 17, 1995, and entitled, "Buried Electrode Drum for an 
10 Electrophotographic Print Engine with a Controlled Resistivity Layer", which is a 
continuation-in-part of U.S. Patent No. 5,276,490, and entitled, "Buried Electrode 
Drum for an Electrophotographic Print Engine", which U.S. Patents are incorporated 
herein by reference. 

[0059] The paper is retrieved from one of two paper supply bins 178 or 180. The 
15 paper supply bin 178 contains one type of paper, typically 8%" x 11 " paper, and the 
paper bin 180 contains another type of paper, typically % X A" x 14" paper. The paper 
bin 178 has the paper stored therein selected by a first gripping roller 1 82, which is 
then fed along a paper path 1 80 into a nip 1 82 between two rollers and then to a nip 
1 84 between two rollers. This is then fed to a paper path 1 86 to feed into a nip 1 88 
20 between two rollers. The paper in the nip 1 88 is then fed into a nip formed between 
two precurl rollers 190 and 192, which have different durometers to cause the paper 
to have a curl bias applied thereto in the direction of the curvature of rotation of the 
transfer drum 142. The operation of the pre-curl rollers is described in detail in U.S. 
Patent No. 5,398,107, issued March 14, 1995, and entitled, "Apparatus for Biasing 
25 the Curvature of an Image Carrier on a Transfer Drum" (Atty. Dkt. No. TRSY- 

22,574). The paper from the bin 180 is extracted by a gripping roller 189 and 
pushed along a paper path 1 91 to the nip 188 and therefrom to the pre-curl rollers 
190 and 192. 
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[0060] The paper is fed from the nip between the two pre-curl rollers 190 and 192 
at the attachment point 176. At the attachment point 176, an attachment electrode 
roller 194 is provided which is operable to operate on a cam mechanism (not shown) 
to urge the roller 194 against the surface of the drum 142 to form the attachment nip 
5 176. This is done during the initial attachment of the paper to the drum 142. 

Typically, this attachment electrode roller 194 is connected to ground. The surface 
of the drum 142 is charged to a positive voltage of between 800-1,000 volts. The 
voltage is disposed on the surface of the drum 142 by a positive electrode roller 196 
that contacts the surface of the drum 142 at a point proximate to the photoconductor 

10 drum 144. Since the electrode 194 is grounded, the voltage will decrease along the 
surface thereof until a lower voltage is present at the attachment point 176. When 
the paper reaches the transfer nip 146, the portion of the surface of the 
photoconductor drum 144 in the nip 146 has a potential thereof reduced to ground 
such that the charged particles will be attracted from the surface of the 

15 photoconductor drum 144 to the surface of the paper on the drum 142. 

[0061] For a multiple pass operation, the attachment electrode 176 will be pulled 
outward from the drum and the paper allowed to remain on the drum and go through 
the transfer nip 146 for another pass. When the final pass has been achieved at the 
transfer nip 146, the picker 172 is swung down onto the surface of the drum 142 to 
20 direct the paper on the surface of the drum 142 to the fuser 174. A discharge 

electrode 198 is then swung down into contact with the drum 142 to provide a 
discharge operation before the surface of the drum enters the nip 176 for the next 
paper attachment process. 

[0062] When the paper is fed into the fuser 174, it is passed into a nip between two 
25 rollers 200 and 202, both of which have different durometers. Typically, there is 
one roller that is formed from a metallic material and one roller that is formed of a 
soft material. The rollers are oriented with the roller 200 having the smaller 
durometer, such that a reverse bias curl will be applied to the paper that is the 
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opposite direction of the curvature of the drum 142. This will remove the curvature 
added to the paper. One of the rollers 200 is heated such that the transferred image 
is "fused". The paper is then fed into a paper path 204 by a pair of rollers 206. The 
paper path 204 is fed to a set of output rollers 208, which feed bins 210, 212 and 214 
5 for each of the printers 136, 138 and 140. Again, these are conventional print 
engines, although the speeds of the print engines may be different. 



[0063] Referring now to FIGURE 5, there is illustrated a flowchart depicting the 
operation of the virtual printing system. For this description, the following terms are 
defined: 



10 N = number of pages in a single document 

M = copies 

E = number of engines 
P = number of pages 
i = the engine number. 



15 [0064] The flowchart is initiated at a start block 230 and then proceeds to a 

decision block 232. A decision block 232 multiples the number of pages N by the 
number of copies M and determines whether this number if greater than or equal to 
the number of engines. If not, then the program flows along a "N" path to a function 
block 234 to utilize only a single engine for the print job. However, if the number is 

20 greater than the number of engines, then the program proceeds along the " Y" path to 
a decision block 236 to determine the number of copies M is greater than the number 
of engines E. If not, the program flows along a path "N" to a decision block 238 to 
determine if the number of pages in a single document "N" is greater than or equal 
to the number of engines. If not, the program will flow along a "N" path to a 

25 function block 240 to utilize the only M engines with the ith copy in the ith engine. 

Therefore, if there are ten engines and only five copies, then the fifth copy of a job 
will be in this ith engine. If, however, the number of copies in a single document is 
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greater than the number of engines, then the program will flow along a " Y" path to a 
function block 242 wherein the copies will be distributed in accordance with the 
equation: 



N x M 

p = £L^1 (ooi) 

[0065J If it was determined in the decision block 236 that the number of copies M 
5 was greater than the number of engines with the number of copies times the number 
of pages in a single document also being greater than the number of engines, then 
the program flows along the "Y" path from decision block 236 to a decision block 
244 to distribute copies. These are distributed in accordance with the algorithms 
illustrated in FIGURE 5 with respect to four of the engines E b E 2 , E 3 and E 4 . E 1? E 2 
10 and E3 are also associated with function blocks 246, 248 and 250, each operating in 

accordance with the above equation, one associated with function block 242. 
However, E 4 will flow to a function block 256 wherein the distribution will be as 
follows: 

P 4 = N*M -(Pj) + P 2 +2 P 3 ) (002) 

[0066] Referring now to FIGURE 6, there is illustrated a flowchart depicting the 
1 5 operation for a duplex print job. In the flowchart of FIGURE 6, a face up output is 

considered which is initiated at a block 260. The function block then flows to a 
decision block 262 to determine if the value of N is even. If so, the program flows 
to a function block 264 to print the jobs N-2, N-4 2. The program then flows to a 
decision block 266, which determines whether the value of N is odd. However, if N 
20 was odd at decision block 266, the program would flow along the "N" path to the 
output of the decision block 266 and then to a function block 268 to print the N + 1 
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copies and blank copies and then print the N - 1, N - 3, ... 1 pages. The flowchart 
would then flow to a function block 270. It is noted that if N is even at decision 
block 266, the program would flow to the function block 270. Function block 270 is 
a function block wherein a user annually turns the output stack 180° without 
5 flipping the stack and then puts it back in the drawer of the printer from which it 

came. The program then flows to a decision block 74 to determine if the value of N 
is even, and if so, to the function block 270 along the "Y" path to print the pages 1, 

3, 5, ... N-l, and then to a decision block 278 to determine if the value of N is odd. 
The program at this point will flow along the "N" path to a N block 280. However, 

10 if the value of N is determined to be odd at decision block 274, the program will 

flow through the output of decision block 278 and to the input of a function block 
282 which will print the pages 1 , 3, 5, ... N. 

[0067] Referring now to FIGURE 7, there is illustrated a flowchart depicting the 
duplex operation with a face down output, which is initiated at a block 284 and then 
15 proceeds to a decision block 286 to determine if the value of N is even. If so, the 
program then flows to a function block 288 along the "Y" path to print the pages 2, 

4, 6, ... N. If it was determined that the value of N is odd, the program would flow 
along an "N" path to a function block 290 to print the pages 2, 4, 6, ... N-l . The 
program 288 would flow to a decision block 294, which determines if N is odd and, 

20 if not, flows along a "N" path to the output of function block 290, the output of a 

decision block 294 is input to function block 290. The output of function block 290 
flows through a function block 296, as well as the output along the "N" path of 
decision block 294. Decision block 296 indicates the manual operation wherein the 
user flips the output stack without turning it 1 80° and then inputs it back into the 

25 drawer of the printer from which it was obtained. The program will then flow to a 
decision block 298 to determine if the value of N is even. If so, the program flows 
along a "Y" path to a function block 300 and the pages 1, 3, 5, ... N-l and then to the 
input of a decision block 302, If the value of N is odd, the program flows along the 
M N" path from decision block 298 to the output of decision block 308 and to a 
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function block 306 to print the pages 1, 3, 5, ... N. The output of the decision block 
302 along the "Y" path also flows to the function block 306 when N is even, and the 
flowchart flows along the "N" path to an "END" block 310, this being the path from 
the function block 306. 

5 

[0068] In general, to provide routing of the different images or pages to the 
various print engines 16 provides the ability for the system to make certain decisions 
about how a particular job is output. This is facilitated by the fact that each print 
job, when it has been initially assembled and transmitted to the system, is 

10 disassembled during the RIP operation and then buffered in the form of separate and 
distinct pages. With knowledge of print related information for each of the pages in 
a given job, additional processing can be performed on those pages. This processing 
can be in the form of routing the pages to engines that are more adapted to the 
particular printing operation associated with that particular page. For example, a 

15 page that has no color on it would be better handled by a dedicated black and white 
engine as opposed to a page having color on it being handled by a color engine. 
Typically, color engines, although they do have a black and white mode, operate 
best in the color mode. Dedicated black and white engines are significantly faster 
than color engines operating in the black and white mode. 

20 [0069] One example of a type of problem that occurs when attempting to handle a 
print job having mixed color and black and white sheets is that where a high speed 
black and white print engine can be provided to print black and white pages more 
efficiently than a color engine with black and white capability. By incorporating 
different types of engines as a portion of the overall virtual system in the print 

25 engine 1 6, a higher level of versatility will be facilitated. One reason that color 

engines have difficulty in switching from color to black and white is that these types 
of engines have an internal sequencer that must be programmed when changing 
printing mode (color versus black and white). To reload the sequencer requires the 
engine to wait for the current page to exit the fuser. 
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[0070] In order to facilitate this system, the print engines 16 are grouped into 
physical engines of similar characteristics. For example, a set of four color physical 
engines can be configured as one virtual engine and a set of four high speed black 
and white engines can be configured as another virtual engine. To the outside 
5 world, these virtual engines simply appear as a high speed entity (the speed is equal 
to the sum of the individual engines rated print speed). In this case, the outside 
world will see two high speed devices, one of which has color capability. 



[0071] There are two methods of collation that exist in the present system, 
automatic and gather. In an automatic collation system, collated documents are 
10 generated and the user is then required to stack them and perform whatever finishing 
is required. For example, if there were 10 copies of a 6 page document, the 
following sequence would be printed: 

1,2,3,4, 5,6 

1,2,3,4, 5,6 

15 

1,2,3,4, 5, 6 (10th copy) 
This particular sequence will result in the collated copies being present in the output 
bin. Of course, the particular number of engines can be configured and controlled to 
20 determine how to most efficiently provide the collated copies. However, once the 

copies are in the stack, they are in a sequential collated configuration. 



[0072] The gather method of collation is employed when external finishing and 
collation is available. In this case, all copies of each individual page must be printed 
before the next page in the document is printed. Therefore, without the multiple 
25 engine concept as described hereinabove, this would require one engine to perform 

all of the necessary copies of page 1, then the necessary copies of page 2, etc. This 
would result in a stack that had M sheets of page 1 , followed by M sheets of page 2, 
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etc. In the above example with the 10 copies of the 6 page document, the following 
sequence would be present: 

1,1,1,1,1,1,1,1,1,1,1 

2, 2,2,2,2, 2, 2,2, 2,2,2 

5 3 , 3 , 3 , 3 y 3 y ^ J ? ^ J ^ ? ^ ? ^ 

4, 4,4,4,4, 4, 4,4,4, 4,4 

6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6 

This arrangement, of course, would result in a single stack of the 6 pages, which 
10 would then be placed in the external finishing and collating hardware. 

[0073] Referring now to FIGURE 8, there is illustrated a diagrammatic view of 
the collation operation and the gather operation. In this particular example, there is 
illustrated an example wherein a document having "N" pages and "M" copies is to be 
provided for. In a collation operation, it can be seen that the final stack results in a 
15 sequence of the first page, the second page, the third page and the Nth page followed 

by the first page of the next copy, the second page, third of the Mth copy. This will 
continue for all M copies. In the gather method, the stack is configured of M of the 
first pages, M of the second pages and M of the third pages, only 3 pages illustrated 
for simplicity purposes. This will comprise a single stack. 

20 [0074] There are instances where the gather method of collation has a significant 

speed advantage over the automatic collation method. Using the above noted 
example with 6 pages and 10 copies, assume that pages 2, 4 and 6 are color pages 
and pages 1 , 3 and 5 are black and white pages. Also assume that it is desired to 
have 100 copies in order to notice a difference between the two operations. If the 

25 print job is to be printed with the color virtual engine, a time penalty is allotted each 

time the color engine is switched between the color mode and the black and white 
mode and back to the color mode. In one type of color engine, a Canon P320 
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model, this penalty is on the order of 8 seconds. In this example, the time penalty 
will occur between pages as follows: 

1- 2 black and white to color switch 

2- 3 color to black and white switch 
5 4-5 black and white to color switch 

5-1 color to black and white switch 
This will result in 32 seconds for each copy. If this is multiplied times 100 copies, it 
will result in almost an hour of lost time just for switching between the color and 
black and white modes on this engine. With a four engine virtual engine, the print 
10 distribution would look as follows: 



Table 1 



Engine 1 


Engine 2 


Engine 3 


Engine 4 


1-6 x 25 


1-6x25 


1-6 x 25 


1-6x25 



It can be seen from Table 1 that each physical virtual engine in the four engine 
15 virtual engine would print 25 copies of the 6 page document in the order 1 , 2, 3, 4, 

5, 6, such that each physical engine would have a time penalty of 25x8=200 seconds. 



[0075] If the gather collation method is utilized in the above example, the pages 
would be divided among the engines as set forth in Table 2: 

Table 2 



Engine 1 


Engine 2 


Engine 3 


Engine 4 


1x100 


2x50 


4x 100 


5x50 


2x50 


3 x 100 


5x50 


6x100 



In this example of Table 2, the first engine prints 100 copies of page 1 and 50 copies 
of page 2, engine 2 prints the other 50 copies of page 2 and 100 copies of page 3 and 
25 so on. This results in each engine only making one mode change in order to allot 
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only a single 8 seconds per engine and, since they are running in parallel, it is only 8 
seconds for the entire virtual engine. 

[0076] A further optimization could be applied to achieve the following print 
sequence set forth in Table 3: 
5 Table 3 



Engine 1 


Engine 2 


Engine 3 


Engine 4 


1x100 


3x50 


2x 100 


4x50 


3x50 


5x 100 


4x50 


6x 100 



In Table 3, the black and white pages have been grouped and printed on engines 1 
10 and 2 and the color pages have been grouped and printed on engines 3 and 4. As 

such, there are no penalty hits due to mode changes, since each engine is never 
required to change modes. In order to achieve this configuration, of course, it is 
necessary to know whether or not a page contains color information. This 
information is determined after the RIP operation in the RIP 22, as described 
15 hereinabove. 

[0077] Referring now to FIGURE 9, there is illustrated a block diagram 
illustrating the process flow for both the automatic collation operation and the 
gathering collation operation. A document is input to the system, as represented by 
a box 320, which in this example is a three page document where the value of "N" is 

20 equal to three. The next operation will be defining the job, which is represented by 
a box 322 wherein the number of copies "M" is defined. Thereafter, it is necessary 
to define the manner in which the stack will be configured. This stack is basically 
the overall result at the output of the engine. Since this is a virtual print engine, 
multiple output bins will be utilized to form the stack. Of course, if there were a 

25 single engine, the stack would be that which results in the output bin of the single 
engine. With multiple engines, it is only necessary to extract the documents from 
each of the engines in sequence and place them into a single stack such that the 
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overall stack will be as if it were printed with one engine. This is defined as the 
image task manager (26) in FIGURE 2. The operation of the stack definition will be 
determined to be an automatic collation or gathering collation operation. If it is 
automatic, the process will flow to a block 326 to place the individual pages in the 
5 correct order and then output them to a parser 328 which then distributes them to a 

plurality of print engines 330. 

[0078] If the gather operation were selected at the stack define block 324, the stack 
would be defined as set forth in a block 328 which would be as described above with 
respect to FIGURE 8, i.e., the stack would be M copies of page 1 , followed by M 
10 pages of page 2 and M pages of page 3. This would be input to a parser 332 for 
output to a plurality of print engines 334 which are configured as a single virtual 
engine. By configuring them as a single virtual engine, the output bins from the 
print engines 334 will in fact provide the stack as defined in the box 328. 

[0079] For the gathering operation, in order to determine how to define the parsing 
15 operation for the stack, it is necessary first to determine the number of sheets that 

will be present for each job. This is the number of pages in a document "N" 
multiplied by the number of copies M M". It is then necessary to determine how 
many sheets are to be accommodated by each engine which number of sheets is the 
value of M Q" which is defined by the following equation: 

NxM 
^ E 



20 Where: M = copies 

N = number of pages in the document 
E = number of engines 

Q = number of pages per engine in gather operation 
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This is illustrated diagrammatically in FIGURE 10 where it can be seen that the 
boundary for each of the print engines in the overall virtual printer (there being 
illustrated 4 printers) is defined such that, when finished, the outputs from each of 
the printers can be sequentially stacked to form the stack defined in block 328. The 
5 boundary for each of the "Q" values is something that is defined, in the present 

example, by equally dividing the total number of pages by the number of printers. 
However, the boundary could be defined as the page break. If there were 4 printers 
and 4 or less pages, it would be quite easy to route each page to a separate printer. It 
is only necessary to fix this boundary such that the right engine will get the right 
10 page. For example, if one of the printers in the set of printers defined as the virtual 
printer were a color printer and one page were color, the system could route the 
color page to that particular printer. It is then only necessary for the operator to 
understand that this particular configuration requires the outputs to be assembled in a 
predetermined manner. 

15 [0080] Referring now to FIGURE 1 1, there is illustrated a diagrammatic view of 

the overall parsing operation which is defined with a parsing block 340. This 
parsing block is operable to determine how the job is to be split up between the 
engine and this is then output in the appropriate order and stored in a page buffer 
342. The page buffer then sequentially outputs the data to a block 344, which 

20 basically performs the operation of the engine manager, that is, it routes the copies 
to the correct print engine. The entire operation is facilitated in a manner that allows 
pages to be output by the parsing block 340 in a particular sequence that will match 
that of the engine selection. Each of the engines may not print at the same speed 
and, therefore, the sequence that the pages are output by the parsing block 340 may 

25 not be the exact sequence that they are input to the print engines. The block 344 
determines which pages goes to which engine and operates in conjunction with the 
parsing operation to provide the overall desired result. For example, one printer 
may be a much higher speed printer whereas the second printer may deal with a 
higher resolution page. Since the higher resolution pages take longer to print, it may 
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be desirable to output a number of pages to the higher speed printer such that it 
completes its portion of the job prior to the lower speed printer. This will result in 
the parsing block 340 outputting the black and white pages initially in order to 
maintain the speed rate for the high speed printer and at a slower rate color pages for 
5 the low speed printer, such that they will be fed to the low speed printer at the 

appropriate rate. This allows a single page buffer 342 to be provided for all of the 
printers. 

[0081] In another aspect of the present invention, the system is operable to divide 
a particular job into multiple jobs and provide "virtual job routing". When virtual 

10 job routing is utilized, the job is examined and then converted into two separate jobs, 
depending upon whether it may be faster to group the operations, for a job such as a 
mixed color and black and white job. The color job would then be defined as a 
single group and would be submitted to a color virtual engine, wherein the black and 
white job would be grouped separately and submitted to a high speed virtual engine. 

15 Each of the color virtual engines and black and white virtual engines are a 

combination of multiple engines. As an example, a high speed black and white 
engine is provided that is assumed to be four times faster than the black and white 
mode of the color engines. In the virtual job router, two jobs would be generated as 
illustrated in Tables 4 and 5. 

20 Table 4 - Black and White Job 



Engine 1 


Engine 2 


Engine 3 


Engine 4 


1 x75 


1 x25 


3x50 


5x75 




3x50 


5x25 




Table 5 - Color Job 


Engine 1 


Engine 2 


Engine 3 


Engine 4 


2x75 


2x25 


4x50 


6x75 




4x50 


6x25 
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In the example noted above with respect to Tables 4 and 5, it can be seen that the 
basic job has been divided into two completely separate jobs that will then be 
submitted to a job manager, with each to be completed by its respective virtual 
engine. This involves both error handling and other aspects that would be handled 
5 by a single printer. It can be seen from the example from Tables 4 and 5 that a 

significant speed advantage has been achieved by not burdening the color engines 
with the black and white pages. In many cases, a cost savings will also be achieved 
since it is cheaper to print black and white pages on a black and white engine than it 
is to print on a color engine. Of course, in this example, the number of color pages 
10 was equal to the number of black and white pages. In most instances, this is not the 
case, with the black and white pages usually outnumbering the color pages, which 
makes the virtual routing a more important process. 

[0082] Referring now to FIGURE 12, there is illustrated a graphical representation 
of the process. The process is initiated at the software RIP in a block 350, which is 

15 operable to retrieve the initial multi-page document and the RIP the document into 

separate pages, which pages are separate and distinct and have associated therewith 
parameters that define the nature of the document as to printing, i.e., whether it is 
color or black and white, the possible resolution of it, bit depth thereof, etc. The 
process will then flow to a block 352, wherein the job will be defined as being a 

20 virtual job routing job and will be divided into two or more jobs. In the present 

example, there is a black and white job and a color job. The process will then flow 
to a virtual job router block 354, which is the parsing operation. The black and 
white job is routed to a first job block 356 and the color job is routed to a second job 
block 358. Both of these jobs are handled by a job manager 360, illustrated in 

25 phantom. The job manager will route the black and white job to a first virtual 

engine, represented by a block 362, which has associated therewith four black and 
white print engines 364. The job manager will route the second job associated with 
the block 358 to a second virtual engine 366, having associated therewith four color 
print engines 368. It should be noted that the job manager 360 will essentially 
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perform the operation of the parsing and will ensure that pages that are extracted 
from the internal page buffer (not shown) will be routed to the appropriate engine in 
the appropriate manner and at the appropriate time. It is noteworthy that the pages 
will be routed to the virtual engine 362 at a much higher rate and they will be routed 
5 to the virtual engine 366, as the color engines are typically slower than the high 

speed black and white engines. It is only necessary that the integrity of the overall 
stack that was defined in the stack block 328 of FIGURE 9 be maintained. It is 
important to note that the print engines 334 in FIGURE 9 basically will be grouped 
as the two virtual engines 362 and 366 when virtual job routing is utilized and the 

10 gather collation method is utilized. In general, virtual job routing will utilize the 
gather collation method. It should be understood, however, that the primary 
advantage provided by virtual job routing is that a particular page can have the 
parameters thereof examined after the page has been assembled separate from the 
initial multi-page print job, and a determination made as to how to handle that 

1 5 particular job. This will allow the job to be routed to the most efficient engine. 

[0083] Referring now to FIGURE 13, there is illustrated a flow chart for the 
overall virtual job routing operation. The flowchart is initiated at a start block 370 
and then proceeds to a block 372 in order to perform the software RIP operation. 
This software RIP operation is the operation described hereinabove that allows the 

20 image for each page to be extracted out of the original input print job from the 

workstation to provide a stand alone page. After the document has been ripped and 
stored as a single page, the program then flows to a function block 374 to receive an 
input as to the number of pages in the document "N". The program then proceeds to 
a function block 376 to receive the number of copies that are to be made of the 

25 document, this being the value "M". The program then flows to a decision block 
378 to determine if the pages are determined to have job specific pages, i.e., certain 
pages are color and certain pages are black and white, or, alternatively, that certain 
pages require processing by a certain one of the print engines or a certain one of the 
group of print engines as a virtual job. If so, the program will flow along the "Y" 
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path to a function block 380 in order to parse the jobs. The program will flow to a 
function block 382 to define the "Q M boundary for the jobs, i.e., how many sheets 
are to be routed to each engine, and then to a function block 384. Function block 
384 creates the stack for each job with the defined "Q" boundaries disposed therein, 
5 which "Q" boundaries defined which portion of the stack goes to which printer. The 
program will then flow to a function block 386 to transfer the pages to the page 
buffer and then to a function block 388 in order to transfer the pages to the particular 
printer of the function of the job that is being performed and the printer that is 
designated. The program will then flow to an end block 390. 

10 [0084] If the decision block 378 had determined that there were no job specific 

pages, the program will then flow along the "N" path and proceed with the normal 
virtual print engine parsing, as described hereinabove, this indicated in a function 
block 392. The program will then flow to a function block 394 to transfer the pages 
to the page buffer as a function of the parsing operation and then to a function block 

15 396 to transfer the pages from the page buffer to the virtual printer. The program 
will then flow to the end block 390. 



[0085] Referring now to FIGURE 14, there is illustrated a general block diagram 
of the overall system illustrating in more detail the operation of the electronic 
collator and the Print Station Manager. As described above, whenever a document 

20 is received, it is processed through a software RIP, such that individual bit map 
pages can be defined, which individual bit mat pages constitute images, which 
images are independent as to the print parameters associated therewith, such as 
color, bit resolution, bit depth, etc., but are associated with a document. In the block 
diagram of FIGURE 14, a multi-page document is input to the system. This 

25 document is input from a PC or some type of user. In general, each of the multi- 
page documents constitutes a job. In FIGURE 14, there are illustrated four 
documents, a multi-page document 400, a color document 402, a hybrid document 
404, and a black and white document 406. The multi-page document 400 may be 
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any type of document which includes multiple pages. Document 402 is a document 
that is defined as operable to be printed on a color print engine. The document 404 
is a hybrid document which can have black and white pages and color pages. The 
document 406 is in an entirely black and white document. It should be understood 
5 that the virtual print engine of the present invention is operable to convert each of 

the documents into single individual bit-mapped pages, which images are stored on a 
page-by-page basis for each document. Thereafter, as described above, these pages 
are distributed to various engines in a parallel manner, depending upon the 
characteristics of the page, the availability of the engine and, in general, how best to 
10 match a given page in accordance with its characteristics with a given engine in 

accordance with that engine's characteristics. This facilitates maximum throughput 
through the engines and maximizes the use of the engines' capabilities. 

[0086] There are illustrated four print engines 408, labeled PE1 , PE2, PE3 and 
PE4. In a preferred embodiment, the print engines 408 are realized with a Canon 

15 P320 color laser printer print engines. Each engine is rated at 3 ppm for four-color 
pages and 12 ppm for black pages. In a mixed document, black-only pages are 
printed at 12 ppm and color pages at 3 ppm. The print engines are configured to 
accept letter-size (or A4) or legal-size paper and prints on only one side, although 
double-sided printing could be facilitated with another type of engine. In general, 

20 the print engine in the preferred embodiment utilizes a 60-to-80 micron spot and 

images at 600 x 600 dpi. 

[0087] The print engines 408 are interfaced on the input side thereof with a print 
station manager 410 through an interconnect 412, the interconnect 412 defined 
hereinabove as the PCI interface, which will be described in more detail 
25 hereinbelow. The print station manager 4 1 2 in general is operable to define the way 
in which jobs are initially assembled and reported to the printers. The output of each 
of the print engines 408 is basically disposed in bins associated with the print 
engines and these are then fed to a document assembly operation, represented by a 
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block 414. This is any type of technique for retrieving documents from the print 
engine and placing them in an appropriate order. In one embodiment, this is done 
manually. 



[0088] The Print Station Manager 410 receives the input therefrom from an 
5 electronic collator 418, which is in part described hereinabove with reference to 
FIGURE 9 as the stack define block 324. This electronic collator 418 receives an 
input from a job parser 412, which is operable to retrieve pages from a memory 414, 
which pages are basically compressed bit maps. These compressed bit maps are 
oriented such that each page defines a bit mapped image, with each page having 
10 associated therewith information regarding the parameters of the page with respect 
to printing. These parameters define such things as resolution, bit depth, color/ 
black and white, etc. The compressed bit maps, as described above, are derived 
from a software RIP 416, which interfaces with a spooler/OPI server 419. The 
spooler 419 is operable to receive the documents 400-406. 

15 [0089] The software RIP 416, as described hereinabove, is a PostScript RIP 
created by Harlequin as the Level 2 ScriptWorks software RIP running under 
Windows NetWork. The configuration for this software RIP in the present 
embodiment requires 64 MegaBits of memory and a 4-GB hard disk for storing 
compressed rasterized pages. In general, the software RIP can rasterize an entire 

20 job, store it on disk, and then start sending it to another recording engine, this being 
the preferred mode when utilizing slower recording engines and when rasterized 
data must be saved on disk for reuse later. Alternatively, the RIP is operable to pass 
rasterized pages to the print engines at the same time it writes them to disk. This is 
what is referred to as the "writethrough" mode, as it effectively results in bypassing 

25 of the print queue. In cases where the engines are not able to keep up with the RIP, 

the system terminates transmission of data directly to the engine and continues to 
pass pages to the disk, from which they are fed to the engine at a later time. The bit 
maps are compressed utilizing a compression algorithm which is referred to as a 
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"pack bit" compression algorithm, a conventional algorithm. These rasterized pages 
are available to be printed and reprinted, either on a document or a page basis, at any 
time. 



[0090] This software RIP is operable to provide dispersed screening techniques 
5 and conventional half-tone screening techniques, in addition to a contone dot 

generator. The user can select which form of outlet is desired for any situation. 
Additionally, the software RIP rasterizes data at a variety of bit depths, from 
600x600 dpi at eight bits per pixel per color for contone output to 600x1200 dpi at 
one bit per pixel to be screened by a screening algorithm that is proprietary to the 
10 Harlequin software RIP. When rasterizing data at 1200 dpi for output at 600 dpi, 
the present system utilizes the extra data to modify the laster spot utilizing the print 
engine's ability to modulate the beam. 

[0091] The software RIP is connected to the printer via a PCI interface, as 
described hereinabove and which will be described in more detail hereinbelow. This 

15 PCI interface will allow two engines to be connected to the PC bus and a parallel 
data channel associated therewith, which provides a data transfer rate of 13 
megabytes per second per engine, fast enough to handle hundreds of compressed 
pages a minute. The PCI bus feeding these engine interfaces operates at up to 120 
MB per second. The job parser 412 is operable to split virtual print engines across 

20 multiple print stations, as described hereinabove, which in conjunction with the 
electronic collator 418, is operable to set up and monitor queues, support "virtual 
printers/ 1 and provide diagnostic feedback and status of the print stations, which is 
received from the print engines 408. 

[0092] The electronic collator 41 8 is, as described hereinabove, the process of 
25 rasterizing every page in a document only once and then printing the pages in order, 
such that no mechanical or manual collation or sorting is required on the output of 
the print engines 408, this being a function of the actual way in which the print 
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engines bins are configured. The compressed bit maps are saved, such that multiple 
copies of the pages can be printed subsequently at the engines' full rate of speed, this 
being the result of rasterizing on a page-by-page basis, with no additional rasterizing 
being necessary for each multiple page, i.e., once a page is rasterized, it can be 
5 printed any number of times without requiring further rasterization of the original 
input. The job parsing operation, as described above, is operable to determine the 
total number of pages in the job (the number of pages in a document times the 
number of copies of the document in the job), and then spread the job out 
"equitably" among the available engines, such that the output of one engine placed 
10 on top of the other engine yields a complete job, as if it had come out of one engine. 

This, of course, is a function of the number of engines utilized and the way in which 
their output bins are disposed. However, each of the engines is combined in a 
particular configuration setup that will define a virtual printer that will be associated 
with a particular job. 

1 5 [0093] Whenever a multi-page document requires multiple pages to be printed, it 
is first necessary to rasterize the entire document and store it in the memory 414. 
Thereafter, a virtual job stack is created that has one copy on top of the other, as 
described above with respect to the stacks 326 and 328 in FIGURE 9. Boundaries 
are then defined, as noted above with respect to the "gather mode" in FIGURE 10, 

20 which defines which portion of the stack goes to which engine and the portions of 
the stack designated for those engines are routed to the engines via the distribution 
process, as described above with respect to block 14 in FIGURE 1 . The key aspect 
of this system is that a document is rasterized only once, but emerges as multiple 
copies (or gathered copies) and that the job is printed at the speed of multiple 

25 engines in parallel. 

[0094] The electronic collation step is completely automatic, transparent to the 
operator, which operator merely directs the print station as to which job to print and 
how many copies are needed, the print station comprising all of the printers. This 
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creation of the job stack and defining of boundaries of the job stack for distribution 
to the engines is determined in a relatively short amount of time on the order of 
seconds. The purpose is primarily to ensure that the resources are utilized at their 
maximum ability. At the completion of a press run, the operator then stacks the 
5 various output piles on top of each other to complete the collated job. Of course, as 
will be described hereinbelow, an automatic "finishing" system could be utilized to 
extract the documents and put them in the appropriate stacks. It is only important 
that, when the stacks are defined within a given printer, there is some indication, 
such as a separator page, that will allow the particular stack created between 
10 separators, to be assembled with another stack from another printer in the desired 

print job output. 

[0095] If one of the print stations, Le., one of the print engines 408, is down, the 
job will automatically be reconfigured such that it is parsed over the remaining print 
stations. An output will then be provided to instruct the operator how to arrange the 
15 pages for pickup from the output bin. 

[0096] With respect to duplex printing, duplexing can be performed by a dedicated 
engine or, with an engine that does not have an automatic duplex feature, a "work- 
and-turn" procedure is utilized. In this procedure, after the first sides are printed, the 
lights on the print station console blink red and send a message to reload the paper. 

20 The operator then removes the sheets printed on one side from the output of the print 
engine 408, turns them over and places them in the input tray. The process then 
prints the other side and places them into the output bins. The result is pre-sorted 
output of the entire job. The operator then moves from one machine to the next, 
putting the sets in one collated stack. If needed, slip sheets fed from the printers' 

25 manual input trays can be inserted between jobs or between copies, these being 

separator sheets. This technique can be facilitated, since the system has stored the 
individual pages and associated with those pages information regarding which job it 
is associated with and the page number it is associated with. Therefore, once the job 
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is rasterized and the compressed bit image is stored, it is only necessary to extract 
the even-numbered pages, print them, turn over the documents, and then print the 
odd-numbered pages. 

[0097] By providing the page-by-page basis, this allows a merge operation to be 
5 facilitated. If the user desires, the print station manager 410 can merge pages of a 

"form" document with pages of another job. This is to be distinguished from a 
conventional word processing system in that the image formed of a bit mapped 
image for each page can merely be printed in a predetermined order. For example, a 
page from a form document could be inserted between pages 10 and 1 1 of a single 

10 other document, such that the final document results in page 10 being followed by 
the form page and then being followed by page 1 1 . This merely requires the job 
stack to be redefined and redefine the output job. Of course, if two jobs are input at 
the same time and are to be merged, it will require initial rasterizing and storing of 
the jobs prior to the merging operation. If the jobs have already been rasterized and 

15 pre-stored, then it is only necessary to create the virtual job stack, which is relatively 
quick. 

[0098] The spooler 4 1 9 is operable to optimize printing over the network. The 
spooler can take jobs directly from a workstation and route them either to disk or 
directly to the RIP 416 in order to begin processing. This is primarily directed 
20 toward Macintosh computers. For general IBM-compatible PC's, the jobs will go 
directly through the print manager on the Windows NT print manager directly to the 
spooler. After the jobs are rasterized by the RIP 416, they are then stored on the 
disk 414 prior to output to a print engine. 

[0099] Jobs may be printed as contone images or screened. The spooler will 
25 publish print cues representing printer characteristics. This will then be displayed to 
the user as printers in the print setup menus for Windows. Also, different queues 
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can be provided with other characteristics, such as different paper sizes or collating 
requirements. 

[0100] Referring now to FIGURE 1 5, there is illustrated a block diagram of the 
lower level architecture between the generation of a virtual printer and the print 
5 engine 408. As described above, the virtual printer is a configuration setup in which 

a certain number of printers in the system are utilized together to produce a single 
job. Just as queues represent characteristics that affect how the RIP will process the 
file, the virtual printer defines the way in which the engines are configured, which 
affects how the REP will feed them with the pages to the printers. Each "virtual 

10 printer" is actually one or more physical engines, which virtual printer essentially 

represents the print engines that are available to the RIP sending a document to be 
printed, i.e., the final destination is defined. The virtual-printer system is a method 
to allow the user to define fewer than the entire series of printers for association with 
a single job, such that one or more engines are available to print a different job. 

15 Overall, each system and each different site may set up as many virtual printers as it 

desires with its allocated engines. For example, an operator could set up two 
engines as one virtual printer, the other engine as a second virtual engine, and all 
four engines as a third virtual printer. Then, the job could be directed from the REP 
to the third virtual printer, thus using all the printers to output the same job. 

20 Alternately, two separate jobs could be printed concurrently, each using one of the 

first two virtual printers. 

[0101] In the block diagram of FIGURE 15, there are illustrated three virtual 
printers 420, labeled virtual printer A, virtual printer B, and virtual printer C, 
respectively. Associated with the virtual printers 420 are two distinct allocation 
25 systems, an engine allocator 422 and a resource allocator 424. The engine allocator 

422 is responsible for managing the physical print engine resources, while the 
resource allocator 424 manages the memory resources. Since disk usage, CPU 
usage and bus bandwidth are directly related to memory usage when sending bit 
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maps to the engines, managing memory usage effectively manages the other 
resources. 

[0102] In general, the engine allocation block 422 is required to give each virtual 
printer 420 access to the print engines 408 in a controlled and predictable manner 
5 that will guarantee maximum use of each engine. The engine allocator 422 works in 

concert with the electronic collator 418, while the electronic collator 418 itself 
generates job stacks for each engine, the engine allocator 422 ensuring that there is a 
physical print engine 408 available to execute a particular job stack. 

[0103] The resource allocator 424 has two basic functions: memory management 
10 and performance management. If a system has only a limited amount of memory, 

and all engines wish to utilize this memory to load bit maps at once (which contain 
more data than available memory), the system may cause unpredictable behavior 
unless the memory is managed. In some systems, it is more desirable to dedicate 
more memory usage (bus CPU time and bus bandwidth) to the RIP versus the 
15 physical engine or vice versa. With the resource allocator 424, this is a relatively 

straightforward method which can be presented as a slidebar to the user. One end of 
the slidebar increases engine performance while the other increases RIP/spool 
performance. The block diagram of 15 depicts the basic communication and data 
flowpath from the virtual printers 420 to the print engines 408. The virtual printer A 
20 is illustrated as utilizing print engines 408 labeled PE1 , PE2, and PE4, virtual printer 
B is designated as utilizing only print engine 408 labeled PE 3, and virtual printer C 
is not printing. 

[0104] Each of the print engines 408 has associated therewith in the software a 
physical print engine object 426, labeled PPE1, PPE2, PPE3 and PPE4, respectively. 
25 The physical print engine objects 426 provide control of the engine. All access to 
the print engines 408 is controlled through the PPEs 426 that are associated 
therewith. The PPE 426 is responsible for maintaining real-time status of the print 
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engine and is also operable to isolate the associated print engine 408 from the 
remainder of the system. This permits different types of print engines to have 
different PPEs. New engine types can be added to the system by simply developing 
newPPEs. The PPE 426 maintains the physical link to the engine. A logical link is 
5 also maintained by the engine allocator 422. In this manner, if the user physically 

switches cables, the logical link is maintained. 

[0105] Each of the PPEs 426 drives a kernel device engine 428. These are 
created during system utilization to develop kernel mode device objects for each 
printer port, with these portions then registered in the system hardware register. 
10 These kernel objects are different from PPEs. During initialization, it is a function 
of the engine allocator 422 to enumerate each of these physical ports, create a PPE 
object, and attach one per port. Once assigned a port, the PPE object then begins 
communication with the associated physical print engine 408 through the kernel 
mode device engine 428 and the associated kernel mode device object. 

15 [0106] The engine allocator 422 will maintain a list of pointers into the PPE 

objects and kernel mode device objects to access status functions, as well as control 
functions. As such, the engine allocator 422 will be connected to the PPEs 426 
through interconnections 430, which are logical interconnections to the virtual 
printers 420. With these connections, any routine system can request status of a 

20 physical engine 408 from the engine allocator 422. When a request for real-time 
status is presented to the engine allocator 422, it reads the status from the PPE 426 
associated with that engine and returns to the call-in function. All status requests 
must go through engine allocator 422. The request can be made of logical as well as 
physical engines. The engine allocator 422 maintains the logical and physical 

25 mappings of each engine. 

[0107] The PPE object 426 is instantiated from a derivative from the C Printer 
class. The C Printer class is the base class all printer objects are built upon. In a 
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preferred embodiment, there is only a single printer class associated with the Canon 
P320 engine class. The interfaced printer object is the same regardless of the type of 
physical printer they are connected to. The PPE object isolates the rest of the system 
from the physical device. Each time a new device is to be connected to the system, 
5 an associated PPE class must be developed for that device. 

[0108] The kernel device engines are output to a controller object 436, which is 
then operable to interface a host adapter 43 8 , there being one for each two printers 
408. This is essentially the PCI adapter described above. 

[0109] The print engine C Printer class is, as described above, specific to the 
10 Canon P320 laser engine. This class must communicate through the kernel mode 

driver to the physical engine. The higher levels of communication protocol are 
implemented in this class, while the lower level layers are implemented in the kernel 
device engine 428. Since the Canon P320 does not send any unsolicited messages, 
the messaging protocol between the Canon P320 class and the engine is a 
15 master/slave protocol, with the engine being the slave. However, it should be 

understood that solicited messages can be accommodated with a different engine. In 
the preferred embodiment, the Canon P320 class must maintain a real-time engine 
status. This is accomplished via polling the engine every three seconds. Only 
changes are updated during this polling interval. Each time the Canon P320 class 
20 detects that the engine has been powered on or reset, an entire status update is 

performed. 

[0110] In order to understand the engine allocation, the concept of "job stacks" 
will be further elaborated upon. A job stack is basically a dynamically sized array of 
instructions which is delivered to the PPE 426. Each entry in the array is defined by 
25 a number of variables. There is a Number of Copies variable, which instructs the 

PPE 426 to print each page a defined number of times before moving on to the next 
page. There is a Begin Page variable to define when the first page of a document is 
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to print, and an End Page variable which defines the last page of the document for 
this instruction. A Command variable is also input, which is utilized for special 
commands, such as printing separation pages. In the following example in Table 6, 
a Command value of M 0" indicates nothing, while a Command value of " 1 " indicates 
5 that a job separator page must be printed. Job stacks are dynamic and can contain 
any number of entries. The example in Table 6 utilizes a ten-page document that is 
to be printed with four copies utilizing three engines, with a separator page between 
jobs feature turned on. Table 6 is as follows: 



Table 6 





PPE1 


PPE2 


PPE3 


Instruction 1 


1, 1, 10,0 


1,4, 10,0 


1,7, 10,0 


Instruction 2 


1,1,3,0 


1,1,6,0 


1, 1, 10,0 


Instruction 3 


1,0, 0,1 


1, 0, 0, 1 


1,0,0,1 



Examining the above Table 6, it can be seen that PPE1 will print one copy of pages 
15 1-10, followed by one copy of pages 1-3 of a document followed by a job separator. 

PPE2 will print one copy of pages 4-10, followed by one copy of pages 4-6 followed 
by a job separator. PPE3 will print one copy of pages 7-10, followed by one copy of 
pages 1-10, followed by a job separator. Since the printing is face-down printing, 
once the job is complete, the user simply takes the pages from PPE3 and stacks them 
20 on top of the pages from PPE2 (still face down), and then takes this new stack and 
places it on top of the pages from PPE1 for a completed and collated job. 

[0111] The engine allocator 422 provides for Controlled Dynamic Engine 
Allocation. The goals of engine allocation are two-fold: provide equitable (round- 
robin) allocation of engines, while at the same time maximizing the use of individual 
25 engines. Controlled engine allocation means that virtual printers consist of 



Atty. Dkt No. TRSY-25,474 



42 



predefined sets of print engines and cannot utilize engines outside of the set with the 
predetermined job stack for a physical engine unable to be changed "on-the-fly. M 

[0112] As an example, if Virtual Printer A consists of physical engines PE1 and 
PE2, it can never utilize physical engines PE3 or PE4, unless the system is 
5 reconfigured. As an example, if a virtual printer consisted of three print engines and 
was presented with a one-page job, it would not be efficient to tie up all three 
physical engines to complete this one-page job. In this case, the virtual printer 420 
would submit the job to the electronic collator. The electronic collator would then 
return only one job stack. Since there is only one job stack, the virtual printer 420 

10 would request only a single one of its engines. A more complicated case to this is 

one that will be more common. Consider the case of two virtual printers, Virtual 
Printer A and Virtual Printer B, and four print engines, PE1, PE2, PE3, and PE4. 
Virtual Printer A consists of physical engines PE1 and PE2, while Virtual Printer B 
consists of physical engines PE2 and PE3. If a 100-page job is assumed, which 100- 

15 page job has been split up by the electronic collator into job stacks of 50 pages each, 
it is then necessary to process these with the virtual printers 420. If the jobs arrive at 
each of the virtual printers at the same time, one job for one of the virtual printers 
420 and one job for another of the virtual printers 420, since only one virtual printer 
420 can utilize PE2, the other must wait. In this case, assume that Virtual Printer A 

20 received the job first, such that PE1 and PE2 are printing the job for Virtual Printer 
A. If there were no dynamic allocations provided by the engine allocator 422, PE3 
would remain idle until PE2 was released. This is not desirable, since there may be 
more jobs behind the two mentioned, and PE3 is sitting idle, /.e, system resources 
are not being utilized at their maximum potential. If a user walked up to the 

25 console, he would then see several jobs waiting and an engine sitting idle. 

[0113] In the controlled dynamic allocation provided by the engine allocator 422, 
the following sequence of events would occur. First, engines PE1 and PE2 would 
begin printing their 50-page job stacks for Virtual Printer A. Engine PE3 would 
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begin printing its 50-page job stacks for Virtual Printer B for the portion that has 
been designated to be printed by PE3. At a later time, PE1, PE2, and PE3 would 
complete their job stacks at about the same time. Once PE2 is released from Virtual 
Printer A, it can then begin printing its job stack that was designated for being 
5 printed by Virtual Printer B. At this point, engines PE1 and PE3 are available for 
other jobs, thus maximizing throughput. An important rule to note is that PE2 will 
print its jobs for Virtual Printer B in their entirety. Although it may seem more 
efficient to send a portion of the PE2 job stack to PE3 once it is released, this may 
not be the most efficient method for a given mode, since this would mean splitting 

10 the PE2 job stack real-time and printing part of it on PE2 and part of it on PE3. 

This does not provide significant advantages and can cause some collation problems 
when a user stacks the documents after the job has been completed. If additional 
jobs are waiting, the engine usage is the same and no benefit is gained. If this 
approach were taken, the stacking order would be disrupted in an unpredictable 

15 manner for the user, since the PE2 job stack is partially printed on PE3. However, 
with the use of page separators and indicators, this could be achieved. Further, if a 
more sophisticated finishing system other than a user stacking documents were 
utilized, this could be facilitated. 

[0114] Each virtual printer is allowed to only have one request into the engine 
20 allocator 422 at a time. If the engine allocator 422 receives a request from a virtual 

printer that has already queued a request, then the request fails immediately. The 
requesting virtual printer must pass several bits of information to the engine 
allocator. For each physical engine the virtual printer wishes to utilize, it must 
supply a handle for the physical printer (this was obtained by performing logical to 
25 physical mapping), and a handle of an event object to signal when the engine is 

available. This is information that is passed in as a pointer to a list of request 
structures in the engine allocator 422. 
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[0115] It is the task of the virtual printer 420 to create a "thread" to pass the job 
stack to the PPE 426, these threads illustrated in FIGURE 1 5. This thread will wait 
on an event that is signaled by the engine allocator. The engine allocator 422 will 
take the request and sort it into a separate queue for each physical engine. As soon 
5 as an engine becomes available, the engine takes the next request out of the queue 

and signals the event object via a SetEvent If the SetEvent function fails and the 
engine allocator 424 assumes the virtual printer 420 no longer requests the engine, 
the engine allocator 422 will move on to the next request in that queue. There is a 
separate queue for each physical printer PE1-PE4, and the queues are independent of 
10 each other. Each queue entry will consist of a handle for the virtual printer ID and 
the handle for the event handle. 

[01 16] Once the virtual printer has completed a job stack on a particular printer, it 
must then free the physical printer by calling an engine-free handle. At this point, 
the engine allocator 422 will move on to the next request in that engine's queue. 

15 [0117] Engines in an Error state are treated no differently by the engine allocator 

422. It is the task of the virtual printer 420 to decide what to do with an engine in an 
Error state. Virtual printers can still request and be granted use of the physical 
engines in the Error state. If the virtual printer has no use of an engine in an Error 
state, it can then release this physical engine back to the system immediately. If the 

20 virtual printer determines that the Error condition will be corrected, then it can hang 

on to the engine and release it later. A virtual printer does not have to request all of 
its physical engines to print a job. If a virtual printer 420 is configured with three 
physical engines and only receives two job stacks back from the electronic collator, 
then it has the ability to only request two engines from the engine allocator. 

25 [011 8] Referring now to FIGURE 1 6, there is illustrated a flowchart depicting the 

engine allocation operation for setting up the requests in the queue. This is initiated 
at a block 440 and then proceeds to a block 442 to determine if a request has been 
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received from a virtual printer. If not, the program will flow back to the input 
thereof from the "N" path. If a request has been received, the program will flow to a 
decision block 444 to determine if there is an existing request for that virtual printer 
in the queue. If so, the program will flow along a " Y" path to a block 446 to fail the 
5 request and then back to the input of decision block 442 to wait for another request 
from a virtual printer. If this is the only request by the virtual printer and it is not 
currently serving a request from a virtual printer, the program will flow from 
decision block 444 along the "N" path to a function block 440 to receive the handle 
for each print engine defined as being associated with the virtual printer. The 
10 program will then flow to the function block 450 to receive the event object and then 
to a function block 452 to queue the request for each print engine. The program will 
then flow back to the input of decision block 442. 

[0119] Referring now to FIGURE 17, there is illustrated a flowchart depicting a 
portion of the engine allocation operation associated with servicing the request in the 

15 queue. This is initiated at a block 454 and then proceeds to a function block 456 to 

service the request in the queue for a given one of the engines. The program will 
then flow to a decision block 458 if the SetEvent has failed. If the SetEvent 
function fails, then the engine allocator will assume that the virtual printer no longer 
requests the engine and will flow along the " Y" path. If it has not failed, this 

20 indicates that the virtual printer still has possession of the associated physical print 
engine and then flows along a "N" path to decision block 460 to receive the 
FreeEngine handle from the virtual printer. This handle is generated once the virtual 
printer has completed a job stack on a particular printer. If not, the program will 
flow along the "N" path back to the input of decision block 450. If the engine is 

25 determined to be free, the program will flow along the " Y M path to a function block 
462 to service the next request. The H Y" path from decision block 458 will also flow 
to the input of function block 462. After servicing the request, the program will 
flow back to the input of function block 456. 
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[0120] Referring now to FIGURE 18, there is illustrated a flowchart depicting a 
portion of the engine allocation operation associated with the status request. This is 
initiated at a function block 464 and then flows to a decision block 466 to determine 
if a request for status information on a given print engine has been received. If not, 
5 the program will flow back to the input of decision block 466. If so, the program 

will flow along a "Y" path to a function block 468 to retrieve the status of the print 
engine and then to a function block 470 to forward the status to the calling routine. 
The program will then flow back to the input of decision block 466. 

[0121] Referring now to FIGURE 1 9, there is illustrated a flowchart for the 
10 resource allocator. The program is initiated at a block 472 and then flows to a 

decision block 474 to determine if a request has been received from the PPE object. 

If so, the program will flow along a M Y" path to a decision block 476 to determine if 

there is available memory. If not, the program will flow along an "N" path to a 

function block 478 to instruct the engine allocator 422 to queue requests until 
15 memory is freed. If memory is available, the program will flow from the decision 

block 476 to a function block 480 to decrement the available memory and then back 

to the input of decision block 474. 

[0122] If decision block 474 had determined that no request was received from the 
PPE, the program will flow along the "N" path to a decision block 482 in order to 

20 determine if an indication has been made that memory was freed from one of the 
PPEs. If not, the program will flow along the "N" path back to the input decision 
block 474. However, if additional memory had been freed from one of the PPEs, 
the program will flow to a function block 484 to increment the memory and then to 
a function block 486 to send an instruction to the queue. Basically, when a job stack 

25 is forwarded for printing and memory is unavailable, the resource allocator will 
place that job in a queue and it will remain in the queue until the memory is 
available. When the memory is available, the queue is served on a first-in-first-out 
basis. The program will then flow back to the input of decision block 474. 
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[0123] Referring now to FIGURE 20, there is illustrated a block diagram of a 
prior art interface for a conventional PCI bus. CPU 490 is typically provided at the 
heart of any computing system. This typically will interface through a system bus 
492 to a PCI device 494, which then interfaces to a PCI bus 496. The system bus 
5 492 is typically a 64-bit bus, whereas the PCI bus 496 is a 32-bit bus. The PCI bus 

operates with a PCI protocol at a rate of 132 MegaByte/s. The PCI bus 496 is then 
interfaced with a PCI interface device 498 to an I/O bus 500. This then interfaces 
through an I/O chip 502 in a conventional manner to a parallel cable 504 and then to 
a printer 506. Thereafter, the printer operates in a normal convention. This normal 

10 convention is that the parallel cable is interfaced through an I/O device 508 to output 
data to an internal printer RIP 510 which rasterizes the data and outputs it to a 
memory 512 for subsequent input to the marking engine 514. This, again, is 
conventional in the printer 506. The PCI device 494 is basically configured of a PCI 
chip set which is conventional for converting the data and control information on the 

15 system bus to information in the PCI protocol. The PCI interface 498 is basically a 
bus mastering/bus interface. In the present invention, this utilizes a PLX9060, 
manufactured by PLX Technology. In effect, PCI interface 498 and the overall PCI 
protocol allows data to be accepted in large bursts, thus providing relatively high 
throughput for data as compared to a general parallel I/O system. However, in the 

20 prior art system of FIGURE 20, the RIP 510 is disposed in each printer 506, such 

that a PCI interface 498 is required for each printer and the data must be transferred 
to the printer in the form of a multi-page document, RIPPED in the printer and then 
output to the marking engine 514. 

[0124] Referring now to FIGURE 21 , there is illustrated a simplified block 
25 diagram of the interface of the present invention. A PCI interface device 5 1 6, 

similar to the PCI interface 498 in that it utilizes the same chip, is provided for 
interfacing with a PCI bus 518. The PCI interface then is shared by two host 
adapters 5 1 8 for two different printers 520. The host adapter 5 1 8 interfaces with a 
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proprietary cable 522 and then to a print adapter 524, which is then interfaced to the 
printer 520. The print adapter 524 basically controls transfer of data from the cable 
522 to the printer and controls the operations of the printer through various 
control/status lines. Status information can be returned from the printer to the PCI 
5 bus 518. 

[0125] Referring now to FIGURE 22, there is illustrated a block diagram of the 
host adapter. The PCI interface 516 is operable to interface data from the PCI bus 
5 1 8 to an intermediate bus 526 which is a 32-bit bus. The data is then input to a 
FIFO 528, which FIFO 528 is operable to receive the data at a 32-bit word length 

10 and output the data at an 8-bit word length on an 8-bit bus 530. This is essentially a 

double word (32-bit) to byte (8-bit) tunneling FIFO. The order of the double word 
to byte funneling is least significant, D7:0, first, D15:8 next, D23: 16 next, and 
D3 1:24 last. The D3 1:0 bits have a 1 -to- 1 correspondence to AD3 1:0 of the PCI 
bus. Implicit in this process is that all image data (even if it is compressed image 

15 data) must be transferred to the host adapter in multiples of double words. The 8-bit 

bus 530 is then input to a set of drivers 532 which will then drive the cable interface 
534 to output data on a data bus 536, which forms a portion of the cable 522. 
Additionally, control status information is transferred over a plurality of the 
control/status lines 538 wherein directional drivers 540 are provided for interfacing 

20 with a UART 542. The UART is then operable to interface with a status control 

block 544 to interface with the bus 526 to allow communication of the status control 
information between the PCI and the control/status lines 538. A timer 546 is 
provided for controlling the timing functions for the system. The differential drivers 
and receivers utilized in the host adapter are the type DS903C03 1 and DS903C032, 

25 respectively. These devices are manufactured by National Semiconductor. The 

cable interface 534 is a 50 position AMP 0.8 mm CHAMP, Part No. 78796-1, with a 
cable 522 being a custom 16 individually shielded twister pair cable of eight meter 
length. 
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[0126] Referring now to FIGURE 24, there is illustrated a block diagram for the 
print adapter 524. The cable 522 is interfaced through a driver/receiver 550 to a 
FIFO 552. The FIFO 552 is operable to provide an elastic storage capability which 
is then input to an internal data bus 554. The internal data bus 554 then interfaces 
5 with an unpacker/unloader 556, which is operable to retrieve the data from the FIFO 

552 and then decompress this data. The entire operation is controlled by a CPU 560, 
which CPU 560 is operable to control the number of bits per pixel in the unpacking 
operation. This is then input to a transform block 558, which transform block 558 is 
operable to perform a calibration adjustment- As will be described hereinbelow, the 

10 engines in a given virtual printer are "color balanced." In order to do this, each 

engine is calibrated and compared to an internal master color space. The data that is 
transferred to the FIFO 552 is formatted in this master color space. Any aberrations 
of the printer due to parameters associated with a given engine that may yield to 
wear, etc., can be compensated for in this calibration procedure. Once calibration is 

15 complete, a look-up table 562 is loaded with calibration information, which 

calibration information is then utilized by the transform block 558 to correct the 
color space. This data is then input to the marking engine 514. 

[0127] The CPU 560 also interfaces with the marking engine 514 through a 
control/status bus 564. This control/status information can then be read by the CPU 
20 560 to a UART 566, which interfaces with the cable 522 through the driver/receiver 
550. Control information can then be transferred between the cable 522 and the 
CPU 560, such that the marking engine 514 can be controlled and status information 
requested from the marking engine 514. 

[0128] Each print adapter connects to a host adapter using a custom cable 
25 assembly that consists of 16 individually shielded balanced twisted pair conductors 

(one unused pair). 

Name No. Of Pairs Input/Output 



Atty. Dkt. No. TRSY-25,474 



50 



10 



PxD7:0 

PCLKx 

PWEx 

HTXDx 

HRXDx 

PAFx 

EOPx 

FLUSHx 

x=>A or B 



15 



(®HostAdapter) 

Out:Date 
Out:Clock 

Out: Printer Write Enable 

Out: Host Tx (status) 

In: Host Rx (status) 

In: Printer Almost Full Flag 

In: End of Plane (Data extracted out for 

page — used for page sync) 

Out: Resets state of print adapter 



HostAdapter to PrintAdapter Cable Differential Pair Definitions 



15 



PxD7:0+ 
PxD7:0- 



Printer Image Data, D7 is MSB, DO is LSB, sense is positive 
true, and is clocked into the PrintAdapter buffer FIFO on the 
positive transition PCKx. 



20 



PCKx+ 
PCKx- 



Printer Buffer FIFO Load Clock, used to clock image data 
into PrintAdapter Buffer FIFO. Setup and hold times of 
image data are reference to the positive transition of this 
signal. 



25 



PAFx+ 
PAFx- 
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Printer Buffer FIFO Almost Full Flag, sense is negative true. 
The HostAdapter will stop transmitting data and de-assert 
PWEx within 4 positive transitions of PCKx. 

51 



PWEx+ 
PWEx- 



5 



HTXDx+ 
HTXDx- 

10 



HRXDx+ 
HRXDx- 

15 



EOPx+ 
EOPx- 

20 



FLUSH+ 
FLUSH- 

25 



Printer Buffer FIFO Write Enable, sense is negative true. 
This signal is used to enable the loading of a synchronous 
FIFO on the PrintAdapter with image data. When this signal 
is asserted, image data should be accepted by the PrintAdapter 
on the positive transition of PCKx. 



HostAdapter Asynchronous Start/Stop Transmit Data, sense is 
positive true, i.e., the start bit is a logical flow. The 
asynchronous data rate is 9600 Baud. The form is one stop bit 
and no parity. 



HostAdapter Asynchronous Start/Stop Receive Data, sense is 
positive true, i.e., the start bit is a logical low. The 
asynchronous data rate is 9600 Baud. The form is one stop bit 
and no parity. 



End of Plane Pulse, sense is positive true. Asserting this 
signal for at least 3 positive transitions of PCKx will result in 
an interrupt being generated on the PCI bus by the 
HostAdapter (interrupt support logic must have the EOP 
interrupt unmasked). 



Printer Buffer FIFO and Support Circuitry Reset, sense is 
negative true. This signal should be used by the PrintAdapter 



Atty. Dkt. No. TRSY-25,474 



52 



to flush the image data FIFO and to re-initialize image 
generation circuitry. 

[0129] Referring now to FIGURE 24, there is illustrated a timing diagram 
illustrating a typical host adapter unload sequence. The frequency of the clock is 
5 13.75 Megahertz. 

[0130] As will be described hereinbelow, there is a command FLUSHx, which is 
an output from the system to the printer that is operable to reset the state of the print 
adapter. This is utilized for a situation where there is no page synchronization. The 
FLUSH operation is operable to flush the FIFO 552 in the print adapter between 

10 pages, such that there is a clean state. This occurs at the end of a plane (or page) 

after the EOPx signal is generated by the print adapter. With page synchronization, 
on the other hand, information is provided that indicates that the FIFO 552 is flushed 
and the print adapter is ready to receive a new page of information. Page 
synchronization also provides for counting the number of pages to determine how 

15 many pages have been printed. If a page is not received in a predetermined amount 

of time, then an Error condition is generated. At the EOPx, the system then looks at 
the FIFO 552 to determine if it is empty. If it is not empty, this indicates that all the 
information has not been transferred from the FIFO and, thus, an error is indicated. 
In any event, this indicates to the system that a given page has not been printed and 

20 either this page needs to be reprinted or sent to another engine. In order to facilitate 
this page synchronization, of course, it is necessary to know what the status of the 
printed page is when the end-of-page signal is generated. If page synchronization is 
not utilized, the FLUSH signal is utilized to ensure that an error occurring on one 
page does not carry over to the next page. 

25 [0131] Referring now to FIGURE 25, there is illustrated a block diagram of a 

prior art method for handling color spaces. CPU 580 is provided which interfaces 
with a number of different color devices, a scanner 582, a display 584, a film 
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recorder 586 and a printer 588. Due to color balancing, most systems have used 
what are referred to as "device profiles" which resulted from a color management 
system specification that was created by the International Color Consortium (ICC). 
These device profiles are typically generated by the manufacturer, or in some cases, 
5 by the user, which describes the color characters of a particular device. Therefore, 
each of the devices 582-588 would have a device profile associated therewith, which 
is stored in a block 590. These device profiles are provided for allowing an input 
from a scanner 582 to either be displayed on display 584 or to be printed on printer 
588, with a translation being performed therebetween that utilizes the color 
10 independent space as the intermediate. The actual transformation is performed by 
the CPU 580, which reads the device profile link and performs the mathematics 
necessary to transform from one native space to another. This, of course, occurs on 
the user's machine and it results in a significant speed impediment. 

[0132] Referring now to FIGURE 26, there is illustrated a block diagram of the 
15 prior art process flow. The input device that is being mapped to the output device is 

illustrated as having a first color space in a block 592. This is then mapped through 
the device one color profile in a block 594 to a master color space, the XYZ color 
space, in a block 596. This is then mapped through the device two color profile in a 
block 598 to the device two color space, in a block 600. At this point, the color 
20 space should be acceptable for printing and it is then routed to the printer through 
the RIP 602 and to the marking engine 604. However, it is noted that this must be 
performed prior to the RIP operation, which RIP will rasterize each of the pages for 
input to the marking engine 604. However, there is one significant disadvantage to 
this type of operation when processing pages in accordance with the multiple 
25 printing virtual print engine concept described hereinabove. This is the fact that, 
first, the operation is performed prior to rasterization and, second, that it must be 
performed for each page; that is, each time a job is created and sent to the printer, 
the translation must be performed. Further, when utilizing multiple printers, as in 
the present system, then this matching or balancing must be performed for each 
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printer. This creates some difficulties, in that the printers are not necessarily defined 
prior to the RIP operation but, rather, after the pages are ripped and stored. 

[0133] Referring now to FIGURE 27, there is illustrated a block diagram of the 
balancing method of the present invention. The input device exists in the device one 
5 color space, as represented by a block 606. This is mapped to a system color space 
in a block 607 through a color matching algorithm in a block 608. This matching 
algorithm is basically that described above with respect to the operations performed 
between blocks 592 and 600 in FIGURE 26; that is, device one color space is first 
converted to the master color space, the XYZ color space, and then mapped from the 

10 XYZ color space to the system color space in block 607. The system color space, in 
the present invention, is basically the device profile of the generic printer that is 
utilized in the system. Therefore, if the Canon C320 engine were utilized in the 
system, then that would constitute the system color space. Therefore, the device one 
color space would be mapped through its device one color space to the master color 

15 space and then through the Canon C320 color profile to the system color space. 

This constitutes a reference color space. Of course, if all of the engines are 
calibrated and operated identical, then any engine in any Canon C320 engine on the 
system would print identical to another. However, this is not the case, since all 
engines print slightly different. As such, each would have a slightly different color 

20 profile which would have to either be iteratively determined or defined by the 
manufacturer. This is difficult if not impossible to implement. 

[0134] In the present system, the system color space is defined as being that for a 
standard printer, which is defined prior to the RIP operation. During the RIP 
operation, in the preferred embodiment, the color matching operation performed is a 
25 part of the RIP operation, such that after going through a RIP operation, as 
illustrated by a block 610, there will be rasterized images for each page of a 
document that have been color balanced to the system color space. This rasterized 
image will then be routed to the desired engine via the methods described 
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hereinabove with respect to the virtual printers and physical print engine objects, etc. 
The marking engines in FIGURE 27 are illustrated as being three marking engines 
612, 614 and 616. Each of the engines 612-616 has associated therewith a color 
mapping block 618, 620 and 622, respectively. Each of these color mapping blocks 
5 6 1 8-622 is operable to adjust the color of the bit mapped image that is forwarded 

thereto to account for aberrations in the marking engines 612-616 as compared to the 
standard engine which was utilized to generate the device profile used to convert all 
color spaces to the system color space. This color mapping function is a calibrated 
function, which will be described hereinbelow. This is facilitated with the use of the 
10 lookup table 562 described herein above with reference to FIGURE 23. 

[0135] The color mapping devices 618-622 allow each of the engines 612-616 to 
be mapped to the system color space after the RIP operation. The mapping process, 
as will be described in more detail hereinbelow, first renders the engines linear in 
response, such that similar changes in density are achieved for similar changes in 

15 data. This is a combination of an internal linearization algorithm that runs on power 
up and an additional linearization added. This process utilizes a manual gamma 
calibration which is facilitated by setting the lookup table to a 1 : 1 ratio with no 
calibration difference between the system color space and that of the printer and then 
running a test pattern therethrough. The test pattern is then examined with a 

20 colorimeter to determine if the printed image represents the image that should have 
been printed. If not, an offset is determined and stored in the lookup table. For 
contone images, there are typically 256 values. Each of these values can have a 
mapping value associated therewith, such that when a bit value is input to one of the 
color mapping devices 61 8-622, the value in the lookup table is an output. For 

25 example, if a value of 255 were input and the lookup table determined that it should 

be 2 1 7, then a value of 2 1 7 would be output to the marking engine. 

[0136] Referring now to FIGURE 28, there is illustrated a flowchart depicting the 
operation wherein the lookup table is created. The flowchart is initiated at a block 
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626 and then proceeds to a block 628 to set the lookup table to a 1 : 1 ratio, such that 
when an 8 bit value is input to the transform block 558 of FIGURE 23, the same 8 
bit value is output. The program then flows to a function block 630, wherein a test 
pattern is set to the output device and printed. This test pattern consists of four 
5 bands of 256 steps each, each step being a different density of toner, associated with 
each of the expected 8 bit values. These 8 bit values extend from 0 to 256. In 
general, the 8 bit values for each of the colors cyan, magenta, yellow are equal The 
program then flows to a function block 632, wherein this pattern is read into the 
colorimeter. The colorimeter is of the type X-rite DTP51 colorimeter. This is to be 
10 distinguished from a densitometer, which measures only the reflectants from a 

surface to determine density. The colorimeter is based upon measurement of 
wavelength and determines the percentage of the XYZ space, this being "device 
independent" color. As such, different devices can have the same density reading 
with a densitometer, but a different percentage reading with the colorimeter. 

15 [0137] The colorimeter will basically determine a value for each of the spaces and 

provide an output therefor. The program will then flow to a function block 634 to 
compare the output of the colorimeter to the system color space values that would be 
expected to be on the colorimeter. There is a standard table that is provided for the 
colormetric values that are associated with an 8 bit input value. For example, if the 

20 maximum density at the 8 bit value of 255 were found associated with that generated 

when an 8 bit value of 217 was input to the printer, then one would expect that the 
generation of an 8 bit value of 217 would result in the correct output color. This 
would in effect be the mapping function which is determined by taking the 
difference in a function block 636 and then creating the mapping values in a 

25 function block 638. These mapped values are then downloaded to the print adapter 
in the lookup table 562, as indicated by a function block 640, and then the program 
flows to an end block 642. For each printer, this procedure can be followed to 
determine the lookup table values, which lookup table values will operate on each 
"dot" that is to be generated by the printer and at each color. The table that is 
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generated for the colormetric values is already linearized in the generation of that 
table, which table was generated in an iterative manner. The lookup table 562 in 
conjunction with the transform 558 can therefore provide a constraint on the output 
density as a function of the bit value input. 

5 [0138] The above noted procedure is acceptable for color balancing contone 

images, but there are some aspects of bi-level and quad-level techniques that may 
provide a problem, since the different levels are achieved by spacing dots over a 
given area, each of the dots generated at the maximum pixel value. Therefore, there 
is an additional adjustment that is provided for bi-level and quad-level printing 

10 formats. This is an adjustment to the maximum pixel value of 255 that is generated, 
this defines the maximum density value for the printer. In order to determine how 
this value is to be adjusted, a test pattern as illustrated in FIGURE 29 is developed. 
It essentially is a series of patches with the center patches at a location 644 being at a 
50% level such that they are equal portions of cyan, magenta and yellow. These, in 

15 an ideal printer, would provide a gray patch. However, if there are any aberrations 
in the printer, this gray will not be true gray. The patches are adjusted, such that as 
the patterns move to the right in the center location, a patch 646 will be present with 
50% cyan, 51% magenta and 50% yellow. The next patch to the right, a patch 648, 
will have 50% cyan, 52% magenta and 50% yellow. If one moves to the left in the 

20 center row, the first patch, a patch 650, will have 5 1 % cyan, 50% magenta and 5 1 % 

yellow. The next patch in the center row, a patch 652, will have 52% cyan, 50% 
magenta and 52% yellow. This gradual change will be noticeable to the eye and the 
user need only select which patch appears to be the true gray. This is then input to 
the system and the system makes an adjustment in a percentage of the density, which 

25 will be provided as a compensation factor in the lookup table whenever bi-level is 

utilized. 

[0139] Referring now to FIGURE 30, there is illustrated a flowchart depicting the 
above noted operation with respect to the calibration procedure for bi-level and 
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quad-level. This program is initiated at a block 654 and then proceeds to a block 
656 to create the pattern for the bi-level test. The program then flows to a function 
block 658 to visually examine the patches for the most perceptively gray patch. The 
program then flows to a function block 660 wherein the correction factor is 
5 determined for each color at maximum density. This correction is then stored as an 

offset for maximum density at the bi-level and quad-level formats, as indicated by a 
function block 662. The program then flows to an end block 664. 

[0140] Referring now to FIGURE 3 1 , there is illustrated a block diagram of the 
software REP described hereinabove. In general, the RIP is a conventional RIP 

10 which is defined by a block 670. The RIP 670 is a commercially available RIP 

which is utilized to rasterize received pages. The particular software RIP utilized in 
the present invention has the ability to perform the RIP operation depending upon 
the type of document that is received. If a contone image is received, it is RIPPED 
in one method, a color input is RIPPED in another method, a black and white job is 

15 RIPPED in another manner, as is a PostScript file and a PCL file. The RIP 670 has 

associated therewith on the input an input plug-in which is added at input plug-in 
672, which is an added software interface. This interfaces with the input and allows 
the software to define how the RIP 670 is to be configured. There are provided a 
multiplicity of channels 674 that define that configuration, each channel defining a 

20 particular configuration, i.e. , a contone configuration, a black and white 

configuration, etc. The RIP is then operable to provide the rasterized pages on an 
output 676 which interface with an output plug-in 678. The RIP 670, in addition to 
providing a rasterized image, also provides output information as to bit depth, 
resolution, number of pixels per line, etc. This information is provided to the output 

25 plug-in 678, which then forwards this information to a Print Station Manager (PSM) 

680. This information is utilized to generate a page header for each page. This page 
header will define such things as the bit depth of the page, the page size, the number 
of colors, the number of planes, and the resolution, in addition to information 
regarding duplex and simplex printing. These are the characteristics of the particular 
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page. This is then followed by the raw data which defines the bit values for the bit 
mapping image. The information associated with this raw data and the raw data are 
then stored and pointers placed in the Print Station Manager to allow this image to 
be later located. This image, of course, is also associated with job information, such 

5 that the page number of a given job is known. The Print Station Managers can 

utilize this to retrieve these jobs at a later time and manipulate them in any manner 
in order to determine how they will be printed, the order in which they will be 
printed, etc. After the Print Station Manager has received the information from the 
output plug-in 678, this information is then stored and later retrieved. A part of the 

10 PSM 680 is the electronic collator described hereinabove. This electronic collator is 
operable to generate virtual stacks for the document, which virtual stack correlates 
with the potential output configuration of the printers, which virtual stack will be 
directly mapped into that output configuration. For example, if there were four 
printers with four bins, each bin disposed over one on top of the other, the virtual 

15 stack would represent the stack that results in the four bins. In this manner, when 

the user pulls and stacks the contents of the bins, the stack will look identical to the 
virtual stack. This virtual stack is then divided up into job stacks, which are then 
buffered in a buffer area 682 for routing to print engines 684 under the control of the 
print engine objects (PPE) described hereinabove. A job manager 686 manages the 

20 operation of this. In general, the job manager 686 works on a job stack level, 

whereas the PPE operates on a single page level. The PPE, in conjunction with the 
resource allocator, will look at the next instruction in the job stack and execute that 
instruction by fetching the particular page and printing that particular page. The 
PPE will also look at status information and define if an error exists, which will be 

25 relayed to the job manager 686. The job manager 686 can then process this error to 
reroute the remaining portion of the stack to a different printer or reroute the entire 
job stack to a different printer. Therefore, the job manager 686 monitors the error 
information and routes the stack to the appropriate engine, if necessary. 
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[0141] Referring now to FIGURE 32, there is illustrated a flowchart depicting the 
operation of the output plug-in. The flowchart is initiated at a flowchart 686 and 
then flows to a function block 688 to send the job information to the PSM. The 
program then flows to a function block 690 to retrieve the page information from the 

5 RIP, which is then sent to the PSM, as indicated by the function block 692. The 

program then flows to the function block 694 to retrieve a band of the raw data, this 
being the rasterized data. This band of data is essentially a small portion of the 
RIPPED page for all four color planes. This band of data is then compressed, as 
indicated by a function block 696. The purpose for performing the compression 

10 prior to forwarding to the PSM for storage is that this PSM 680 can be facilitated at 
a different location and compression facilitates throughput to a different location. 
After compression, the program will flow to a decision 698 to determine if any of 
the pixels in the different color planes are on. If so, the program will flow to a 
function block 700 along a " Y" path to set a boolean for the cuixent color. This is 

15 essentially flagged and indicates that there is a color present in that particular plane. 

If it were determined that the color planes did not have any pixels turned on, this 
would indicate that this was a black-and-white job. If this were the case, the 
program would flow along the M N" path to the output of the function block 700 for 
all pixels in the plane. The lack of this boolean in the PSM would indicate that it 

20 was a black-and-white job and could therefore be processed in a more rapid manner. 
Once it is determined whether the boolean should be set or that there are no pixels 
on the color plane, the program will flow to a function block 702 to send the band 
data to the PSM, with the information regarding the boolean. The program will then 
flow to a decision block 704 to determine if there are more bands. If so, the 

25 program will flow back to the input of function block 694 to retrieve another band 
of data and, if not, the program will flow to a function block 706 to send an End 
Page message to the PSM. The program will then flow to a decision block 708 to 
determine if the job is complete. If not, the program will flow back to the input of 
function block 690 to get the page information for the next page. When the job is 
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done, the program will flow to the function block 710 to send an End of Job 
message to the PSM. 

[0142] In order to ascertain the toner level in each of the printer engines, the 
present invention utilizes a system whereby the actual rasterized image is evaluated 

5 as to the amount of toner that it will require. This is accumulated over a job stack 
which will be sent to a given printer. Once the job stack has been printed, an 
accumulation register is decremented indicating that the toner value has decreased 
for that particular print engine. Additionally, the accumulator can be examined prior 
to printing the job, but after rasterizing and determining the amount of toner that 

10 will be required, such that it can be determined whether there is sufficient toner 
available to run the print operation on that printer for that particular job stack. 

[0143] Referring now to FIGURE 33, there is illustrated a flowchart depicting the 
toner calculation operation. The flowchart is initiated at a block 720 and then 
proceeds to a decision block 722 to determine if a print job has been initiated. If 

15 not, the program will loop back around to the input. If so, the program will flow to 
the function block 724 to fetch a page of information for the given job and then to a 
function block 726 to accumulate values of pixels in that page. Each pixel will have 
a value that ranges from zero to 255 and these are summed up for the entire page. 
The program then flows to a function block 728 to divide the accumulated value by 

20 the total number of pixels in the page. This will provide the average value. If, for 

example, all the pixels were turned on to their maximum value, this average value 
would be 255. However, if only half of the pixels were turned on to full maximum 
value, the value would be 128. The program then flows to a function block 780 to 
define the value as a percentage of the black page. If it is 100 percent, that means all 

25 pixels are turned on to their maximum value. Any pixels that are turned off or have 
a lower value will lower this percentage. The program then flows to a function 
block 772 to calculate the toner utilized for the given page, Le., this percentage will 
be multiplied by the maximum toner that will be required for that page for each 
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color plane. It should be noted that in a color printer there are four toners, cyan, 
magenta, yellow and black. The toner usage for each plane will be calculated, such 
that if a given one of the toner cartridges for a given color is depleted, this can be 
indicated. 

5 [0144] After the toner use for a given page is calculated, the program will flow to 
a decision block 780 to determine if the last page in the job has been processed. If 
not, the program will flow along a "N" path to a function block 782 to increment the 
job toner value, this being the total toner utilized for a given job. This will be 
divided up into the job stacks, as the job stacks are the smallest number of pages that 

10 will be sent to one of the multiple printers during a print job, the multiple printers 

defining the virtual printer. The program will then flow to the input of function 
block 724 to fetch the next page. 

[0145] After the last page of the job, the program will flow along a " Y" path to a 
function block 784 to set the total toner value equal to the previous toner total value 

15 minus the job toner value, and the program will then flow to a decision block 786 to 

determine if the total toner value is less than a minimum value. If not, the program 
will flow to a function block 788, print the job, and then back to the input of 
decision block 722. If the total toner value is determined to have decreased below a 
minimum value, the program will flow to a function block 790 to send a toner low 

20 command to the user. The program will then flow to a function block 792 to reset 
the total toner value equal to the total toner value plus the job toner value, i.e., the 
value before function block 784. The program will then flow to an end block 794. 
Along this path to the N block 794, the printer will be inhibited from printing that 
particular job stack. Once this error signal is returned to the job manager, the job 

25 manager can then generate an overall default or it can merely reroute the job to 

another one of the printers defined in the virtual printer with an error separator page 
provided thereby. 



Atty. Dkt. No. TRSY-25,474 



63 



[0146] In general, the provision of the accumulated total toner value in a register 
provides, in effect, a "gas gauge" or f, toner gauge" for a given toner module. This 
total toner value will be reset when a new toner is placed in the system. It will be 
reset to a value that approximates the known toner level. Additionally, 
5 characteristics of the toner module and the toner associated therewith in combination 

with the characteristics of the print engine will be utilized to calculate the amount of 
toner that is deposited on a sheet of paper with all pixels on to their maximum value. 
This is relatively easy to determine by running continuous pages through the printer 
until the toner has depleted to a value that is below an acceptable level. This will 

10 provide the total amount of toner output for a given number of pages, which will be 

proportional to that for a single page. This can then be divided down by the 
determined average value. This provides a significant advantage, in that it is an 
actual value, as opposed to an estimated value based upon the input print job. This 
is facilitated due to the fact that the rasterized image for each page in the job is 

15 collected prior to the job being printed. By comparison, conventional systems 

would have no method for determining usage of toner, since the rasterized image is 
developed in the printer after the processing section. 

[0147] In an alternate mode of operation, the toner level determination can be 
utilized to make a determination as to whether to print a particular page. This 

20 determination is made as a function of either the cost of a document or the level of 
toner in a particular print engine. In a first example, consider a large document that 
has multiple colors associated therewith. The user can input information as to cost 
of the toner as a criteria for printing. If the amount of toner can be determined prior 
to printing, then the amount of toner required for a particular job can be determined. 

25 With information as to the amount of toner required and the cost of the toner, the 
total cost of the job can be determined prior to actually printing the job. If the cost 
is too great, then the printing operation can be terminated. This can only be 
facilitated by a system that can make a fairly accurate estimation of the amount of 
toner that is required for a particular job. 
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[0148] In a second example, consider a situation wherein there is a printing job 
that is ongoing and there is a determination made that the toner has fallen below an 
acceptable level. At this point, the print job can be terminated at that engine and the 
remainder of the job routed to another printer, or the entire job can be rerouted to 
5 another printer. This can only be facilitated with a sysem that has the capability to 
determine toner usage coupled with a system that can dynamically reroute pages to 
be printed 

[0149] In a third example, the determined toner level can be utilized to set the 
number of pages to be printed. When the job is evaluated prior to printing to 
10 determine the toner requirements, then the remaining toner for the target printer is 
compared to the total toner required. If there is insufficient toner available for the 
total job, then only the number of pages for which there is available toner will be 
printed. This can only be facilitated with a system that has the ability to print select 
pages after a determination of toner requirement is made. 

15 [0150] Referring now to FIGURE 34, there is illustrated a block diagram depicting 

a power on sequence, which is initiated at a block 796 and then proceeds to a 
decision block 798. Decision block 798 determines whether a power on condition 
has occurred, i.e., whether the system has been turned on. If not, the program will 
flow back to the input of decision block 790 and, if so, the program will flow to a 

20 function block 800 to set a variable "x" equal to "1 The program will then flow to 
a function block 802 to turn on engine M X" and then to decision block 804 to 
determine if a timeout has occurred. This program will loop back to the input of 
decision block 804 for approximately 10 to 15 seconds. At this time, the program 
will flow to a decision block 806 to determine if the value of "x" is equal to a 

25 maximum value. If not, the program flows to a function block 808 to increment the 
value of H x" and then back to the input of function block 802. When the value of "x" 
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has reached its maximum value, the program will flow along the " Y" path to the 
input of decision block 798. 

[0151] The power-on sequence is utilized to minimize power requirements for 
multiple print engines with multiple fusers. These fusers utilize heater lamps that 

5 have low resistance characteristics when the filaments are cold. Therefore, when the 
filaments are initially powered, a current surge will result from a cold start. As soon 
as the lamp filament temperature climbs appreciably, only several seconds or less, 
the current through the lamp stabilizes. The initial current pulse is much greater 
than the average current at a given temperature. Multiple (two or more) lamps on a 

10 single circuit could blow a breaker if the lamps are all started at the same time from 
a cold start. By sequencing the power-on operation, the software can control each of 
the engines, since the print adapter allows control/status information to be 
transferred between the printer and the processing section. 

[0152] Referring now to FIGURE 35, there is illustrated a flowchart depicting the 
15 merge operation, which is initiated at a block 8 1 0 and then proceeds to a decision 

block 812 to determine if the merge operation is to be performed. A merge 
operation, as described briefly hereinabove, is an operation wherein the Print Station 
Manager determines that two or more jobs are to be merged. Since the pages have 
already been rasterized and stored, it is not necessary to go through the RIP 
20 operation again. It is merely necessary to recreate a virtual job stack inserting the 
appropriate pages from one job into another job in the appropriate location. Of 
course, it must be understood that these are rasterized images. Of interest is the fact 
that these pages have associated therewith different printer characteristics. For 
example, a 600x600 DPI job could be merged with a 600x1200 DPI job. Since each 
25 page has associated therewith its own resolution, bit depth, page size, etc., the Print 

Station Manager need only send the job stack to a given printer with the PPE object 
then controlling the operation via the page. Since the command information is 
associated with the page, each page can be treated differently by the PPE object and 
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the print engine. Therefore, a print engine could print one page at the 600x600 DPI 
level and the following page at the 600x1200 DPI level. Even in the event that a 
color page were mixed with a black-and-white page, the color page would be sent to 
the color printer, followed by the black-and-white page sent to the same color printer 
5 (although separate printers could be utilized with automatic finishing steps described 

hereinbelow), such that the color printer will first perform a color operation 
followed by a black-and-white operation. 

[0153] Once the merge operation has been determined, the program will flow 
along a " Y" path to a function block 8 14 to receive the documents and pages to 

10 merge and the order thereof, this determined by the Print Station Manager. The 

program will then flow to a function block 8 1 6 to assemble the virtual job stack with 
the merge documents. This will create a hybrid job. The hybrid job and the 
associated virtual stack will then be divided into individual job stacks for the engines 
and then forwarded to the job manager and the printer, as indicated by function 

15 block 818. The program will then flow to the end block 8 19, as the remaining 

portion of the system in the form of the PPI objects and the kernel device drivers 
will take care of the printing at that time. 

[0154] Referring now to FIGURE 36, there is illustrated a flowchart depicting the 
stack control, which is initiated at a block 820 and then flows to a function block 

20 822. The function block 822 creates the virtual stack and then the program flows to 
a function block 824 to define the job stack for each of the engines. This essentially 
defines the borders between engines. The program then flows to a function block 
826 to transfer the job stacks to the PPE object and then the program flows to a 
decision block 828 to determine if an error has occurred. This error is an error that 

25 has been returned by the engine, which is handled by the PPE object and then is 
relayed to the job manager. If the error occurs, the program will flow along a "Y" 
path to a function block 830 to create a separator page and then to a function block 
832 in order to attach the separator page to the remaining portion of the error job 
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stack, the error job stack being that portion left over after the generation of the error, 
including the page that did not get printed, if this is the case. The program will then 
flow to a function block 834, move the error job stack to another printer in the 
virtual printer set, such that the print operation can be completed. The program will 

5 then flow to a decision block 836 to determine if the print operation is done. The 
decision block 828, when an error has been determined not to have occurred, will 
also flow to the input of decision block 836. If the job is not done, the program will 
flow along an "N" path back to the input of the error decision block 828 which will 
continue until all pages are printed. At this time, the program will flow from 

10 decision block 836 back to the input of function block 822. 

[0155] It can be seen that this system automatically determines errors and, upon 
determination of an error, can automatically change the configuration of the system, 
such that a given job stack can be routed to a different printer. It is only necessary 
to create some type of separator page to indicate to an operator that an error has 
15 occurred and how the job is to be assembled. 

[0156] Referring now to FIGURE 37, there is illustrated a flowchart depicting a 
page synchronization operation. Page synchronization is an operation whereby 
planes of color for each page are evaluated as to their completeness. When a 
complete plane has been printed, the next plane can be printed. If, for some reason, 
20 a given plane is not completely printed, it is possible that the system will go out of 

synchronization, such that the data for the next plane will be disposed behind that 
plane and will be sent to the FIFO in the print adapter. Therefore, it is necessary to 
know that all planes are being printed in a given print job, due to the speed of 
printing. Otherwise, a very large job could be destroyed. 

25 [0157] The page synchronization operation of FIGURE 37 is initiated at function 

block 840 and then proceeds to a function block 842 to check the status signal 
received from the print adapter. The program then flows to a decision block 844 to 



Atty. Dkt. No. TRSY-25,474 



68 



determine if the page transmitted is complete. If not, the program will flow to a 
decision block 846 to determine if an error signal has been received, indicating that a 
problem has occurred and the page was not completely printed upon the generation 
of an EOP (End Of Plane) signal. If the EOP signal has not been received and an 
5 error signal has not been received, the program will flow to the input of function 

block 842 to again check the status. This will continue until an error is determined, 
at which time the program will flow from decision block 846 to a default block 848 
and, when the page is complete with no error, the program will flow to a function 
block 850 to send a new page for processing. 

[0158] Referring now to FIGURE 38, there is illustrated a flowchart for the 
operation in the print adapter. The print adapter is initiated at function block 852 to 
receive the page and then flows to a function block 854 to process this rasterized 
data through the FIFO. The program then flows to a decision block 856 to 
determine if an EOP signal has been generated. If not, the program will continue 
back to the input of function block 854. When the EOP signal has been generated, 
the program will flow along a T path to a function block 858 to examine the 
contents of the FIFO. If the page has been completely printed, the FIFO 858 would 
be empty. This will be determined by decision block 860. If not empty, the 
program will flow to a function block 862 to generate an error signal and, if so, the 
program will flow to a return block 864 and transfer EOP signal out with no error. 

[0159] Referring now to FIGURE 39, there is illustrated a block diagram of an 
alternate embodiment of the present invention. Documents are initially input to the 
software RIP as described above, represented by a block 866. The program then 
flows to a page store operation 868, which is operable to store the rasterized pages, 
25 which are then distributed by distributor 870, this being the operation described 

above with respect to the Print Station Manager and the job manager, in addition to 
the PPE objects. The distributor 870 is basically operable to develop the virtual 
stacks and the job stacks and configure them for routing to a multiplicity of print 
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engines 872. The engines 872 are as described above and can be any type of 
engines, i.e., color, black-and-white, etc. The distributor is controlled by the 
distributor control 876, which is operable to determine how the virtual stacks set in 
the virtual stack queue 874 are divided up into job stacks and routed to the various 

5 print engines 872. This is normally done as described above. The output of the 
print engines 872 are input to an automatic finishing device 878. The automatic 
finishing device 878 is a device that will automatically retrieve the contents of the 
print engines 872 and buffer them in a manner that they will automatically 
determine how the contents of the engines 872 are to be collated into the finished job 

10 output. Each of the print engines 872 also provides status/control information on 

lines 880, which status/control information can return error information back to the 
distributor control 876. The distributor control 876 is operable to configure the 
automatic finishing device 878 and also reconfigure the automatic finishing device 
878. For example, if the distributor control 876 had determined a particular routing 

15 configuration for the job stacks and one of the print engines 872 failed, the 

distribution control could redefine the job stacks and reconfigure the automatic 
finishing device 878. This, therefore, allows the system to ran multiple jobs through 
by dividing them into job stacks and then treating each of the job stacks as 
individual entities and queuing them up and processing them independent of how 

20 fast another job stack in a given job is processed through an adjacent print engine. 

The automatic finishing device 878 will retrieve the output and place it in the proper 
order. 

[0160] Referring now to FIGURE 40, there is illustrated a flowchart depicting the 
operation of the device of FIGURE 39. The program is initiated at a block 882 and 
25 then proceeds to a decision block 884. The decision block 884 determines if a new 
job is printed. If so, the program flows to a function block 884 to queue the 
instructions for the printer and then to a function block 886 to create a job separator 
with a finish code, this separator providing a code that can be read by the automatic 
finishing device 878. This could be as simple as a bar code. The program then 
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flows to a function block 888 to execute the instructions in the job stack for a given 
printer and then to a function block 890 to fetch a given page and print it in 
accordance with the PPE object. The program then flows to a decision block 892 to 
determine if an error has occurred. If not, the program flows to a decision block 894 

5 to determine if the instruction execution has been completed. If not, the program 
will flow back to the input of function block 890. If so, the program will flow to a 
decision block 896 to determine if the last instruction has been received. If not, the 
program flows to decision block 898 to fetch the next instruction and then back to 
the input of function block 888. When the last instruction has been received, the 

10 program flows along the "Y" path back to the input of decision block 884. 

[0161] If a new job has not been received, the program will flow along a "node" 
path from decision block 884 around function blocks 885 and 886. Additionally, 
when an error has been defined, the program will flow from decision block 892 to a 
function block 900 to requeue the operation, i.e., send it to a different print engine 
15 872. 

[0162] The automatic finishing machine 878 can be reconfigured by the 
distribution control 876 or, it can merely act in response to separator pages that are 
provided for each job stack. This will then merely require an individual manually 
moving the stacks from the print engine output bin to the automatic finishing device 
20 878. Alternatively, the automatic finishing machine 878 could automatically extract 
the output from each of the print engines 872 and assemble it in accordance with the 
information received from the distribution control 876. 

[01 63] Although the preferred embodiment has been described in detail, it should 
25 be understood that various changes, substitutions and alterations can be made therein 
without departing from the spirit and scope of the invention as defined by the 
appended claims. 
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